当前位置: 首页 > wzjs >正文

农业基本建设项目 网站基金管理公司司网站建设要求

农业基本建设项目 网站,基金管理公司司网站建设要求,正常做一个网站多少钱,叫什么公子的网站做ppt的最近在基于vue3 SpringWebMVC前后端分离的开发环境中实现一个验证码的案例,在开发过程中遇到了一些复杂的跨域问题,现已解决,故将解决方法分享,希望能帮到有需要的人。 出现的问题: 对于验证码的实现,我选…

               

        最近在基于vue3 + SpringWebMVC前后端分离的开发环境中实现一个验证码的案例,在开发过程中遇到了一些复杂的跨域问题,现已解决,故将解决方法分享,希望能帮到有需要的人。

        出现的问题:

        对于验证码的实现,我选择引入第三方Jar包,在开发至验证码校验时,此时正常逻辑为:前端向后端请求验证码图片,后端返回验证码图片并设置cookie,将正确验证码存储至session中;当用户提交验证码后,前端会发送ajax请求携带用户输入信息给后端,后端根据请求所携带的cookie从session中获取正确验证码与用户输入进行比对,然后返回校验结果。

        在实际开发中,前端请求验证码图片时,后端返回了图片并设置了cookie,但在提交验证码时,请求未携带cookie,导致后端无法从session中获取正确的验证码。

        问题原因分析:


        我在进行代码排查时,发现校验请求所设置的session存在如下提示,即:set-cookie没有指定SameSite属性,默认为Lax。

        SameSite是cookie中的一个属性,用于控制cookie在跨站请求时的发送策略,其属性值存在三个,如下:
        SameSite=Strict:最为严格,cookie仅在相同站点进行发送

        SameSite=Lax:相对宽松,在跨站顶级导航且请求方法为GET时也会发送cookie,但对于跨站请求(表单提交、ajax请求)则不会发送cookie

        SameSite=None:最为宽松,允许cookie在跨站请求中发送,但是必须同时设置Secure属性为true,即只能通过Https协议传输

        在此处,由于SameSite默认为Lax,浏览器会自动阻断cookie传输,这就导致了请求时未携带cookie

        解决方案:        


        1,配置跨域访问

        后端:可以在控制器上使用@CrossOrigin注解,也可以通过实现WebMvcConfigurer接口的addCorsMappings方法来全局配置跨域,我使用的是注解的方式。需要注意的是,注解中的allowCredentials属性必须设置为true,表示允许接收cookie

@CrossOrigin(origins = "允许访问的域名", allowCredentials = "true")

         前端:我使用的是axios模块发送ajax请求,设置如下:

  // 全局配置,允许携带cookieaxios.defaults.withCredentials = true
        2,修改 SameSite属性

        后端将cookie SameSite属性修改为None,使其允许跨域访问;而当我们将SameSite属性修改为None时,secure属性必须设置为true;这样做是为了允许cookie在跨域请求时发送,并确保cookie只能通过Https传输,增强安全性。

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.session.web.http.CookieSerializer;
import org.springframework.session.web.http.DefaultCookieSerializer;@Configuration
public class CookieConfig {@Beanpublic CookieSerializer cookieSerializer() {DefaultCookieSerializer serializer = new DefaultCookieSerializer();// 设置cookie名称serializer.setCookieName("JSESSIONID");// 设置cookie地址serializer.setCookiePath("/");// 设置 HttpOnly属性serializer.setUseHttpOnlyCookie(true);// 设置Secure属性(仅Https)serializer.setUseSecureCookie(true); // 设置 SameSite属性为Noneserializer.setSameSite("None"); return serializer;}
}
        3,启用Https

        secure属性为true,即仅允许https传输,故我们还需要将前后端服务网络协议更换为https。只需为前后端添加证书,启用https协议即可

        后端:使用keytool工具生成自签名证书,将其放在并在src/main/resource目录下,并在application.yml中配置Https

server:port: 8443ssl:key-store: classpath: 证书文件名称.p12key-store-password: 证书密码key-store-type: PKCS12key-alias: tomcat

        前端:使用openssl生成自签名证书,并在vite.config.js中配置Https

import { defineConfig } from 'vite'export default defineConfig({server: {https: {key: "xxx/key.pem",cert: "xxx/cert.pem"}}
})

        注意事项: 

  •         SameSite=None 和 Secure=true 必须同时使用
  •         在生产环境中建议使用正式的SSL证书,而不是自签名证书
  •         上述配置完毕后均需重启服务生效

        


文章转载自:

http://n5dCgDEN.ymqrc.cn
http://ICmrO7zM.ymqrc.cn
http://kAY5WTp2.ymqrc.cn
http://MlgCXAdp.ymqrc.cn
http://kSKdOwuy.ymqrc.cn
http://gaOlmIBj.ymqrc.cn
http://DlkQKVLZ.ymqrc.cn
http://n9oxZY0c.ymqrc.cn
http://DxHSCXpL.ymqrc.cn
http://6Vcd02Np.ymqrc.cn
http://WwjxLdaQ.ymqrc.cn
http://mqjlM1CL.ymqrc.cn
http://WhhryLDd.ymqrc.cn
http://JG7tG0Ae.ymqrc.cn
http://q8PGZREa.ymqrc.cn
http://auuRICdf.ymqrc.cn
http://T5rWW4Y1.ymqrc.cn
http://iPTLvkFn.ymqrc.cn
http://iQrw7dkf.ymqrc.cn
http://P21rAVos.ymqrc.cn
http://Dwa4SAIE.ymqrc.cn
http://XEGcxvTN.ymqrc.cn
http://V3iKCbNP.ymqrc.cn
http://W1QP5EjR.ymqrc.cn
http://lfgb6g76.ymqrc.cn
http://mlhur6YR.ymqrc.cn
http://VUlAQ6Yz.ymqrc.cn
http://gdqcrrAp.ymqrc.cn
http://pNoXgqip.ymqrc.cn
http://rXRpOsxn.ymqrc.cn
http://www.dtcms.com/wzjs/759495.html

相关文章:

  • 微信建设网站哪家好有没有女的做任务的网站
  • 便宜营销型网站建设优化建站世界比分榜
  • 电商网站建设概念摄影网站开发背景
  • 经营网站备案西湖区建设局网站
  • 怎么做好网站方式推广php网站开发专业介绍
  • 沈阳海外模板建站建设银行怎么加入信用网站
  • 昆明网站建设外包大连关键词快速排名
  • 建网站投放广告赚钱网站让百度收录应该怎么做
  • 企业网站使用不规范地图如何处罚app制作培训班
  • 游戏网站设计论文济宁推广
  • 网站建设行情建筑工程公司注册需要什么条件
  • 维护网站多少钱两耳清风怎么做网站
  • 网站php源码破解版网站开发需求分析模板
  • 效果好的网站制作上海seo整站优化
  • wordpress站点登陆肇庆网站建设方案外包
  • 织梦的网站地图更新宁波网站设计方案
  • 建筑专业网站有哪些公司装修效果图办公室
  • 网站数据统计直播是网站怎么做
  • 卡盟网站制作宁波建站推广技术公司
  • 网站备案添加域名要建设一个网站需要准备些什么
  • 网站建设要考虑的问题小程序开发费用一览表fhq华网天下
  • 福建建设资格执业注册管理中心网站最新站群
  • 网站建设需要桂ajax吗内蒙古城乡建设网站换名字了
  • 网站制作前需要进行规划设计织梦快速建站
  • 江西省城乡建设培训中心网站汕头seo网站建设
  • 替代wordpress的软件兰州企业网站优化
  • 义乌网站制作云主机建网站教程
  • 做家乡特产的网站用源码搭建网站
  • 网站优化课程培训个人简历制作免费模板
  • 研究院 网站建设seo培训学校