java-web端前后端分离部署时遇到访问接口跨域问题的解法办法

package com.sldl.controller.app;

import java.io.IOException;
import java.util.HashMap;
import java.util.Map;
import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.log4j.Logger;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import com.alibaba.fastjson.JSON;
import com.sldl.model.app.AppUser;
import com.sldl.model.app.OaUser;
import com.sldl.service.app.RegisterAndLoginService;

/**

  • 用户注册、校验、验证码、登录、退出、忘记密码接口
  • @author lenovo

*/

@Controller
//设置允许跨域–所有端口
@RequestMapping("/oauser")
public class RegisterAndLoginController {

private static Logger log = Logger.getLogger(RegisterAndLoginController.class);

@Resource
RegisterAndLoginService service;	

@RequestMapping("/getVerifyCode")
@ResponseBody
public JSON getVerifyCode(**HttpServletResponse response**,AppUser user){
	**response.setHeader("Access-Control-Allow-Origin", "*");
	response.setHeader("Access-Control-Allow-Headers", "content-type");
	response.setHeader("Access-Control-request-method", "GET,POST");**
	log.info("获取短信验证码接口");
	return (JSON) JSON.toJSON(service.getVerifyCode(user));
}
/**
 * 验证是否已注册并发验证码
 * @param user
 * @return
 */
@RequestMapping("/getVerifyCodeUser")
@ResponseBody
public JSON getVerifyCodeUser(HttpServletResponse response,AppUser user){
	log.info("获取短信验证码接口");
	response.setHeader("Access-Control-Allow-Origin", "*");
	response.setHeader("Access-Control-Allow-Headers", "content-type");
	response.setHeader("Access-Control-request-method", "GET,POST");
	return (JSON) JSON.toJSON(service.getVerifyCodeUser(user));
}

@RequestMapping("/compareVerifyCode")
@ResponseBody
public JSON compareVerifyCode(AppUser user){
	log.info("校验短信验证码接口");
	return (JSON) JSON.toJSON(service.compareVerifyCode(user));
}

/*@RequestMapping("/register")
@ResponseBody
public JSON register(HttpServletResponse response, AppUser user){
	response.setHeader("Access-Control-Allow-Origin", "*");
	response.setHeader("Access-Control-Allow-Headers", "content-type");
	response.setHeader("Access-Control-request-method", "GET,POST");

	log.info("注册接口");
	return (JSON) JSON.toJSON(service.register(user));
}*/
//忘记密码时发送验证码
@RequestMapping("/forgetPWD")
@ResponseBody
public JSON forgetPWD(HttpServletResponse response,AppUser user){
	response.setHeader("Access-Control-Allow-Origin", "*");
	response.setHeader("Access-Control-Allow-Headers", "content-type");
	response.setHeader("Access-Control-request-method", "GET,POST");
	log.info("忘记密码时校验手机号是否存在并发送短信接口");
	return (JSON) JSON.toJSON(service.getVerifyCodeWhenForgetPWD(user));
}

@RequestMapping("/resetPWD")
@ResponseBody
public JSON resetPWD(HttpServletResponse response,OaUser user){
	response.setHeader("Access-Control-Allow-Origin", "*");
	response.setHeader("Access-Control-Allow-Headers", "content-type");
	response.setHeader("Access-Control-request-method", "GET,POST");
	log.info("修改密码");
	return (JSON) JSON.toJSON(service.compareVerifyCodeAndResetPWD(user));
}

@RequestMapping("/login")
@ResponseBody
public JSON login(HttpServletRequest request,HttpServletResponse response,OaUser user){
	response.setHeader("Access-Control-Allow-Origin", "*");
	response.setHeader("Access-Control-Allow-Headers", "content-type");
	response.setHeader("Access-Control-request-method", "GET,POST");
	log.info("登录接口");
	return (JSON) JSON.toJSON(service.login(request,user));
}



@RequestMapping("/exit")
@ResponseBody
public JSON exit(HttpServletRequest request,HttpServletResponse response,OaUser user) {
	response.setHeader("Access-Control-Allow-Origin", "*");
	response.setHeader("Access-Control-Allow-Headers", "content-type");
	response.setHeader("Access-Control-request-method", "GET,POST");
	log.info("退出登录接口");
	service.exit(user);
	Map<String,Object> map=new HashMap<>();
	map.put("code", 0);
	map.put("msg", "退出登录成功");
	return (JSON) JSON.toJSON(map);
}

@RequestMapping("/getUserByToken")
@ResponseBody
public JSON getUserByToken(HttpServletRequest request,HttpServletResponse response,OaUser user){
	response.setHeader("Access-Control-Allow-Origin", "*");
	response.setHeader("Access-Control-Allow-Headers", "content-type");
	response.setHeader("Access-Control-request-method", "GET,POST");
	log.info("获取用户信息接口");
	return (JSON) JSON.toJSON(service.getUserByToken(user));
}

}

请看controller response的设置,通过本设置即可解决前后端接口访问的跨域问题。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值