位置: IT常识 - 正文

SSM前后端分离技术(ssm算前后端分离吗)

编辑:rootadmin
SSM前后端分离技术 文章目录前言一、前后端分离技术和跨域二、两种不同的实现方案1.使用注解实现简单请求的跨域传输2.通过设置请求头和参数实现复杂请求的跨域传输3.将跨域解决方案的代码写进拦截器,或者过滤器实现跨域。拦截器过滤器总结前言

推荐整理分享SSM前后端分离技术(ssm算前后端分离吗),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:ssm前后端分离项目,ssm前后端分离,ajax实现交互,ssm前后端分离,ajax实现交互,ssm算前后端分离吗,前后端分离 sso方案,ssm 前后端分离,前后端分离 sso方案,ssr 前后端分离,内容如对您有帮助,希望把文章链接给更多的朋友!

本篇记录一下使用前后端分离来开发SSM项目。

一、前后端分离技术和跨域

目前,前后端分离项目早已占据市场的主流开发方式。因为它能把web端的代码和java业务实现的代码完全分离开来,使得协同开发变得更加便捷。即,前端工程师和后端工程师只需要预先规定好统一的API,就可以同步开发,大大降低项目的开发周期。 实现前后端分离需要解决的文体就是跨域传输。

我们都知道,在SSM项目中我们使用JSP来访问Servlet接口,实现前后端的交互,归根结底还是在同一个域进行传输,即端口号是相同的。但是在使用前后端分离开发的时候,我们需要在不同的域中间进行数据传输。最直观的就是,后端我们一般使用8080端口,前端可能会使用5500端口,这就意味着,前端和后端处在不同的域内。

SSM前后端分离技术(ssm算前后端分离吗)

跨域传输的根本原因是浏览器端的一种保护程序的机制。当前端域向后端域发送了请求,一般情况下,会有正常的响应数据。但是由于浏览器的保护机制,使得我们无法使用这些响应数据。浏览器需要的是后端必须返回给它一个允许跨域的请求头,否则,返回的数据就无法呈现在前端。那么怎么让后端返回的数据携带正确的请求头就是我们需要解决的问题。

二、两种不同的实现方案1.使用注解实现简单请求的跨域传输

代码如下:

@Controller@RequestMapping( "/login")@CrossOrigin("*")public class LoginController { //自动注入业务层 @Autowired private LoginService service; @RequestMapping(value = "loginVerify",method = RequestMethod.POST) @ResponseBody public ResultLayUi<User> login(String username, String password, HttpServletRequest request){ createLoginSession(username,request); return service.verifyLogin(username,password); }}

我们可以使用@CrossOrigin注解来实现一个临时的跨域传输访问。注解后边的括号可以填写允许跨域访问的域,例如@CrossOrigin(" * ")表示,允许所有的域访问。@CrossOrigin(“http://127.0.0.1:5500/login.html”)允许该IP访问。但是这种解决方案只适合简单请求。不适合复杂请求。

2.通过设置请求头和参数实现复杂请求的跨域传输

通过注解,我们只能实现简单的跨域请求,但无法实现复杂的跨域请求。但是我们可以通过在controller中设置请求头和请求参数来实现复杂请求的跨域传输。代码如下:

@Controller@RequestMapping( "/login")//@CrossOrigin("*")public class LoginController { //自动注入业务层 @Autowired private LoginService service; @RequestMapping(value = "loginVerify",method = RequestMethod.POST) @ResponseBody public ResultLayUi<User> login(String username, String password, HttpServletRequest request){ String origin = request.getHeader("Origin"); // 允许的跨域 response.setHeader("Access-Control-Allow-Origin",origin); // 允许携带Cookie response.setHeader("Access-Control-Allow-Credentials","true"); // 允许的请求头 预检请求需要这个设置 response.setHeader("Access-Control-Allow-Headers", "Content-Type,X-Requested-With,accept,Origin,Access-Control-Request-Method,Access-Control-Request-Headers,Authorization,Access-Token,token"); response.setHeader("Access-Control-Expose-Headers", "*");//响应客户端的头部 允许携带Token 等等 response.setHeader("Access-Control-Max-Age", "3600"); // 预检请求的结果缓存时间 if (request.getMethod().equals("OPTIONS")){ return false; } return service.verifyLogin(username,password); }}

通过这种方式,我们可以实现跨域请求。但是我们需要在每一个Controller方法中都设置这些代码。

3.将跨域解决方案的代码写进拦截器,或者过滤器实现跨域。

上边说到,我们需要在每一个controller中都配置如上代码,造成大量的代码冗余。我们可以把这些代码放进拦截器或者过滤器来实现一个封装的效果。

拦截器package com.glls.java2212.interceptor;import org.springframework.web.servlet.HandlerInterceptor;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;/** * @date 2022/10/10 * @desc 拦截器 一个临时的 跨域解决方案 */public class MyInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { String origin = request.getHeader("Origin"); // 允许的跨域 response.setHeader("Access-Control-Allow-Origin",origin); // 允许携带Cookie response.setHeader("Access-Control-Allow-Credentials","true"); // 允许的请求头 预检请求需要这个设置 response.setHeader("Access-Control-Allow-Headers", "Content-Type,X-Requested-With,accept,Origin,Access-Control-Request-Method,Access-Control-Request-Headers,Authorization,Access-Token,token"); response.setHeader("Access-Control-Expose-Headers", "*");//响应客户端的头部 允许携带Token 等等 response.setHeader("Access-Control-Max-Age", "3600"); // 预检请求的结果缓存时间 if (request.getMethod().equals("OPTIONS")){ return false; } return true; }}过滤器package com.glls.java2212.filter;import org.springframework.stereotype.Component;import javax.servlet.*;import javax.servlet.annotation.WebFilter;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import java.io.IOException;/** * @date 2022/10/10 * @desc */@Component@WebFilter(urlPatterns = "/*", filterName = "CorsFilter")public class CorsFilter implements Filter { @Override public void doFilter(ServletRequest req, ServletResponse resp, FilterChain filterChain) throws IOException, ServletException { HttpServletRequest request = (HttpServletRequest) req; HttpServletResponse response = (HttpServletResponse) resp; String origin = request.getHeader("Origin"); // 允许的跨域 response.setHeader("Access-Control-Allow-Origin",origin); // 允许携带Cookie response.setHeader("Access-Control-Allow-Credentials","true"); // response.setHeader("Access-Control-Allow-Headers", "Content-Type,content-type,X-Requested-With,accept,Origin,Access-Control-Request-Method,Access-Control-Request-Headers,Authorization,Access-Token,token"); response.setHeader("Access-Control-Expose-Headers", "*");//响应客户端的头部 允许携带Token 等等 response.setHeader("Access-Control-Max-Age", "3600"); // 预检请求的结果缓存时间 // if (!request.getMethod().equals("OPTIONS")){ //非 预检请求 放行 ,预检请求 不放行 预检请求 直接响应允许跨域的信息即可 无需访问到后台接口 filterChain.doFilter(request, response); } }}总结

跨域请求的方案有很多,此处只是简单的介绍了两种。分别对应简单的请求跨域和复杂的请求跨域。

本文链接地址:https://www.jiuchutong.com/zhishi/292410.html 转载请保留说明!

上一篇:jQuery 解决低版本安全漏洞 并兼容旧版写法及依赖老插件(jquery版本)

下一篇:【CSS扩展】VUE如何使用或修改element plus中自带的CSS全局变量来定义样式(vue添加css)

  • 淘宝联盟频道推广是什么(淘宝联盟频道推荐怎么关)

    淘宝联盟频道推广是什么(淘宝联盟频道推荐怎么关)

  • 浅谈微信营销推广的特点(1、你认为微信营销的主要推动力是什么?)

    浅谈微信营销推广的特点(1、你认为微信营销的主要推动力是什么?)

  • 华为p40pro是瀑布屏吗(p40是瀑布屏吗)

    华为p40pro是瀑布屏吗(p40是瀑布屏吗)

  • 苹果11旁白怎么关闭(苹果11旁白怎么用)

    苹果11旁白怎么关闭(苹果11旁白怎么用)

  • 小米mix1发布时间(小米mix一代发布会)

    小米mix1发布时间(小米mix一代发布会)

  • realme手机是什么牌子(realme手机官网)

    realme手机是什么牌子(realme手机官网)

  • 抖音作品链接怎么复制(抖音作品链接怎么弄)

    抖音作品链接怎么复制(抖音作品链接怎么弄)

  • iphone电量低需要先充电才能使用闪光灯(iphone电量低需要充电使用闪光灯)

    iphone电量低需要先充电才能使用闪光灯(iphone电量低需要充电使用闪光灯)

  • ios连麦怎么调高其他音量(苹果连麦软件)

    ios连麦怎么调高其他音量(苹果连麦软件)

  • 错误代码1001是什么意思(错误代码1001是什么)

    错误代码1001是什么意思(错误代码1001是什么)

  • 怎么查看手机支持的运营商(怎么查看手机支持OTG功能)

    怎么查看手机支持的运营商(怎么查看手机支持OTG功能)

  • 苹果低电量模式伤电池吗(苹果低电量模式怎么开)

    苹果低电量模式伤电池吗(苹果低电量模式怎么开)

  • 鼠标接口有哪几种(鼠标的接口是什么)

    鼠标接口有哪几种(鼠标的接口是什么)

  • 抖音怎么自定义学校(抖音怎么自定义时间)

    抖音怎么自定义学校(抖音怎么自定义时间)

  • 删了好友还能坦白说吗(删了好友还能坦白吗)

    删了好友还能坦白说吗(删了好友还能坦白吗)

  • win10忘记开机密码强制重置(win10忘记开机密码怎么重置)

    win10忘记开机密码强制重置(win10忘记开机密码怎么重置)

  • 如何把手机照片导入u盘(如何把手机照片传到u盘)

    如何把手机照片导入u盘(如何把手机照片传到u盘)

  • 拼多多闪电退货怎么拒绝(拼多多闪电退货怎么关闭)

    拼多多闪电退货怎么拒绝(拼多多闪电退货怎么关闭)

  • 苹果暗夜模式如何使用(苹果暗夜模式如何开启)

    苹果暗夜模式如何使用(苹果暗夜模式如何开启)

  • 为啥苹果11连不上蓝牙耳机(为啥苹果11连不上大疆无人机)

    为啥苹果11连不上蓝牙耳机(为啥苹果11连不上大疆无人机)

  • 红米k20prodc调光有用吗(红米k20dc调光怎么开)

    红米k20prodc调光有用吗(红米k20dc调光怎么开)

  • 查看腾讯会员谁在用(腾讯会员账号怎么看到)

    查看腾讯会员谁在用(腾讯会员账号怎么看到)

  • 小米8飞行模式在哪(小米飞行模式在哪里设置)

    小米8飞行模式在哪(小米飞行模式在哪里设置)

  • word怎么设置每页行数(word怎么设置每行字数)

    word怎么设置每页行数(word怎么设置每行字数)

  • 链信实名认证安全吗(链信怎么解绑身份证号)

    链信实名认证安全吗(链信怎么解绑身份证号)

  • 腾讯观影券可以看付费电影吗(腾讯观影券可以看超前点播电视剧吗)

    腾讯观影券可以看付费电影吗(腾讯观影券可以看超前点播电视剧吗)

  • 充满电后不拔继续充会有什么危害(充满电不拔充电器会怎么样)

    充满电后不拔继续充会有什么危害(充满电不拔充电器会怎么样)

  • mac输入法打不出中文解决方法(mac输入法打不出简体)

    mac输入法打不出中文解决方法(mac输入法打不出简体)

  • linux系统怎么使用vmstat命令显示虚拟内存状态?(linux zmodem)

    linux系统怎么使用vmstat命令显示虚拟内存状态?(linux zmodem)

  • 个体户开增值税怎么开
  • 开票软件金税盘
  • 开外经证需要预缴税几个点
  • 如何查询开出的全电发票
  • 未达起征点的增值税怎么算
  • 工伤私了赔偿
  • 跨年度费用报销违反什么规定
  • 税务局代扣代缴税费
  • 将产品转为本企业使用
  • 股权转让过户费用
  • 个税由企业承担怎么入账
  • 进项税额转出怎么申报
  • 财税〔2017〕39号商业健康保险个人所得税
  • 企业所得税上个季度赔钱下个季度挣钱
  • 手工发票何时停止使用的
  • 2016年最佳歌曲
  • win10如何设置声音
  • linux如何开启端口
  • 上市公司的股份可以转卖吗
  • 建筑业预缴企业所得税表项目金额填合同金额吗
  • 待抵扣进项税额贷方表示什么
  • 财政应返还额度是什么意思?
  • debian配置
  • php strrchr
  • 企业发放年终奖政府有哪些规定?
  • 企业新产品销售收入数据
  • vue3路由守卫 微信授权登陆
  • php curl 封装
  • 普通发票可以跨年报销吗
  • 增值税普通发票查询真伪
  • 在建工程的前期工程
  • mysql 服务器配置
  • c语言中sizeof是啥意思
  • asp和asp net
  • 应收账款可以挂存货吗
  • 公司什么项目
  • mysql数据库排序
  • 砂石可以开专票吗
  • 应付账款主要账户有哪些
  • 银行利息支出税率是多少
  • 汽油发票怎么开专票
  • 专设销售机构的办公费计入
  • 企业收到退回的银行汇票多余款项
  • 支付股东借款现金流量表怎么填
  • 废品损失是什么要素
  • 电子承兑汇票到期网银上怎么操作
  • 坏账确认方法有哪些?
  • 母公司及子公司增资
  • 公司员工抽奖活动
  • 购进货物的发票确认定虚开,所得税处理
  • 总分类账封面封地和启用页的区别
  • sql server 错误
  • mysql8.0存储过程
  • 在linux系统中安装软件
  • 如何解决女性漏尿问题
  • Vista下jusched.exe进程与禁用
  • centos怎么执行脚本
  • centos6创建文件
  • xp系统怎么调出任务管理器
  • macbook的dock栏怎么不见了
  • linux大于符号
  • win7系统误删文件可以恢复吗
  • win7系统自动注销重启
  • win10系统怎么卸载ie浏览器
  • awk中RS、ORS、FS、OFS的区别和联系小结
  • python如何不换行
  • javascript模块化规范
  • python操作xml文件
  • unity接入安卓sdk
  • python 批量查询
  • jquery删除数据
  • 国家税务局太原税务局官网
  • 怎样从税务局网上交医保
  • 垃圾填埋税率
  • 国税湖南电子税务局官网
  • 山西省网上营业执照申请官网?
  • 资源综合利用企业所得税优惠
  • 北京朝阳区国税局
  • 山西省税务
  • 环保标识码
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设