Ajax跨域请求的解决


test-client的index.jsp里面的Ajax访问test-service的Controller

Controller返回json时无法接接收,JSONP方式处理后可接收

Client:

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>jquery--getJSON方法实现ajax功能</title>
        <script type="text/javascript" src="jquery.js"></script>
        <script type="text/javascript">
		/**
			页面加载完立即执行
		*/
        $(function(){
        	//alert("JJJ");
			$.getJSON("http://127.0.0.1:8080/test-service/json?callback=?&id=123&age=22", function(data) {
				
                alert(data.name);
             });
		
		});
            
        </script>
		
		
		    <script type="text/javascript">
			/**
			触发执行
			*/
            /*$(function() {
                $("#button1").click(function() {
                  
                    //打开文件,并通过回调函数处理获取的数据
                    $.getJSON("userInfo.json", function(data) {
                        alert(data.name);
                    });
                });
            });*/
			</script>		
			

</head>
<body>
	<div class="divTitle">
            <input type="button" id="button1" value="获取数据"/>
        </div>
        <div id="divTip"></div>
		
	
</body>
</html>


Service:

package com.xh.controller;

import org.springframework.http.MediaType;
import org.springframework.stereotype.Controller;
import org.springframework.util.StringUtils;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;



@Controller
public class JsonController {
	//@RequestMapping("/json")
	@RequestMapping(value="/json"/*,produces=MediaType.APPLICATION_JSON_VALUE+";charset=utf-8"*/)
	@ResponseBody
	public String getJson(String id,String callback,String age )
	{
		System.out.println("id:"+id);
		System.out.println("age:"+age);
		String json="{'name':'zhangs121212andsads'}";
		System.out.println(StringUtils.isEmpty(callback));
		System.out.println(json );
		System.out.println(callback );
		if(StringUtils.isEmpty(callback))
		{
			
			return json;
		}
		else
		{
			System.out.println(callback + "(" + json + ");");
			return callback + "(" + json + ");";
		}
		
	}
}

web.xml


<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
	xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
	id="taotao" version="2.5">
	<display-name>tets-service</display-name>
	<welcome-file-list>
		
		<welcome-file>index.jsp</welcome-file>
	
	</welcome-file-list>


	<!-- 初始化spring容器 -->
	<context-param>
		<param-name>contextConfigLocation</param-name>
		<param-value>classpath:spring/ApplicationContext-*.xml</param-value>
	</context-param>
	<listener>
		<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
	</listener>

	<!-- 解决post乱码 -->
	<filter>
		<filter-name>CharacterEncodingFilter</filter-name>
		<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
		<init-param>
			<param-name>encoding</param-name>
			<param-value>utf-8</param-value>
		</init-param>
	</filter>
	<filter-mapping>
		<filter-name>CharacterEncodingFilter</filter-name>
		<url-pattern>/*</url-pattern>
	</filter-mapping>


	

	<!-- springmvc的前端控制器 -->
	<servlet>
		<servlet-name>tets-service</servlet-name>
		<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
		<!-- contextConfigLocation不是必须的, 如果不配置contextConfigLocation, springmvc的配置文件默认在:WEB-INF/servlet的name+"-servlet.xml" -->
		<init-param>
			<param-name>contextConfigLocation</param-name>
			<param-value>classpath:spring/springMVC.xml</param-value>
		</init-param>
		<load-on-startup>1</load-on-startup>
	</servlet>
	<servlet-mapping>
		<servlet-name>tets-service</servlet-name>
		<url-pattern>/</url-pattern>
	</servlet-mapping>
</web-app>



springMVC.xml


<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
	xmlns:p="http://www.springframework.org/schema/p"
	xmlns:context="http://www.springframework.org/schema/context"
	xmlns:mvc="http://www.springframework.org/schema/mvc"
	xsi:schemaLocation="http://www.springframework.org/schema/beans 
		http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/mvc
        http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd
        http://www.springframework.org/schema/context 
        http://www.springframework.org/schema/context/spring-context.xsd">
    
    
    <!-- 配置包扫描器 -->    
    
    <context:component-scan base-package="com.xh.controller"></context:component-scan>
    <!-- 配置注解驱动 -->
    
    <mvc:annotation-driven/>
	<!-- 静态资源映射 -->
	<!-- <mvc:resources location="/category.json" mapping="/category.json"/> -->


	
	
</beans>        



资源下载链接为: https://pan.quark.cn/s/22ca96b7bd39 在当今的软件开发领,自动化构建与发布是提升开发效率和项目质量的关键环节。Jenkins Pipeline作为一种强大的自动化工具,能够有效助力Java项目的快速构建、测试及部署。本文将详细介绍如何利用Jenkins Pipeline实现Java项目的自动化构建与发布。 Jenkins Pipeline简介 Jenkins Pipeline是运行在Jenkins上的一套工作流框架,它将原本分散在单个或多个节点上独立运行的任务串联起来,实现复杂流程的编排与可视化。它是Jenkins 2.X的核心特性之一,推动了Jenkins从持续集成(CI)向持续交付(CD)及DevOps的转变。 创建Pipeline项目 要使用Jenkins Pipeline自动化构建发布Java项目,首先需要创建Pipeline项目。具体步骤如下: 登录Jenkins,点击“新建项”,选择“Pipeline”。 输入项目名称和描述,点击“确定”。 在Pipeline脚本中定义项目字典、发版脚本和预发布脚本。 编写Pipeline脚本 Pipeline脚本是Jenkins Pipeline的核心,用于定义自动化构建和发布的流程。以下是一个简单的Pipeline脚本示例: 在上述脚本中,定义了四个阶段:Checkout、Build、Push package和Deploy/Rollback。每个阶段都可以根据实际需求进行配置和调整。 通过Jenkins Pipeline自动化构建发布Java项目,可以显著提升开发效率和项目质量。借助Pipeline,我们能够轻松实现自动化构建、测试和部署,从而提高项目的整体质量和可靠性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值