js window.location.href,session丢失
时间: 2023-11-15 12:58:16 浏览: 189
当使用JavaScript中的window.location.href进行页面重定向时,会重新创建一个新的httpcontext,这可能会导致session丢失。这是因为session是与httpcontext相关联的,当httpcontext被销毁时,session也会被销毁。因此,当使用window.location.href进行页面重定向时,会创建一个新的httpcontext,旧的httpcontext和与之相关联的session都会被销毁,导致session丢失。
为了解决这个问题,有两种方法可以尝试:
1. 把session数据带到你重定向的页面去,具体参照:点击打开链接
2. 把重定向操作放到后台去做,这样页面就不会创建新的httpContext,session数据就能获取到了。
相关问题
location.href携带参数存在{}重定向
引用\[1\]:问题出在替换地址栏的方式上。使用window.location.replace('XXX')直接替换地址栏时,可能会导致地址栏的参数丢失或出现异常。在你的情况下,项目的地址栏从有key值变成了没有key,然后又跳转到有key值的地址。这是因为Vue路由守卫需要使用next()方法来继续当前导航,而你没有在next()方法中传递需要跳转的路由,导致默认跳转到to对象的路由,即带有key的路由。为了解决这个问题,你可以在next()方法中传递需要跳转的路由,确保地址栏的参数正确。\[1\]
引用\[2\]:如果你想使用location.href携带参数进行重定向,可以使用以下方式:
```javascript
let consturl = window.config.host + "/iip/iip-faceserver/faceSystemData/downLoadExport?url=" + response.data.content; // 下载地址url
var xhr = new XMLHttpRequest();
xhr.open("get", consturl, true);
xhr.responseType = "blob";
xhr.setRequestHeader("token", sessionStorage.getItem('token'));
xhr.onload = function() {
if (xhr.status == 200) {
let blob = new Blob(\[this.response\], { type: 'application/zip' });
var a = document.createElement("a");
var url = window.URL.createObjectURL(blob);
a.href = url;
var farmname = consturl.substring(consturl.length - 21);
a.download = farmname; // 文件名
a.click();
window.URL.revokeObjectURL(url);
}
};
xhr.send();
```
这段代码使用XMLHttpRequest发送GET请求,获取到文件的Blob数据后,创建一个a标签,设置href属性为Blob数据的URL,设置download属性为文件名,然后模拟点击a标签进行下载。\[2\]
引用\[3\]:在你提供的代码中,使用了PHP和JavaScript来实现携带参数的重定向。在PHP代码中,通过session_start()开启了session,并使用$_SESSION数组存储了一些数据。在JavaScript代码中,通过获取到的session_id将其作为参数拼接到URL中,然后使用window.location.href进行重定向。这样就可以在重定向后的页面中获取到session数据。\[3\]
#### 引用[.reference_title]
- *1* [vue window.location.replace替换之后又自动跳回去](https://blog.csdn.net/tan47325/article/details/125263139)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item]
- *2* [如何在window.location.href加请求头(token)示例导出文件](https://blog.csdn.net/sun_pingpuan/article/details/125392972)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item]
- *3* [解决location.href跳转后,丢失用户的session](https://blog.csdn.net/weixin_38615720/article/details/90665620)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item]
[ .reference_list ]
js代码使用href跳转后seesion会丢失
使用`href`跳转会导致页面的重新加载,从而导致之前存储在session中的数据丢失。可以使用以下两种方法来解决这个问题:
1. 使用`localStorage`存储数据
在跳转之前,将需要传递到下一个页面的数据存储在`localStorage`中,然后在下一个页面中读取数据。由于`localStorage`是基于浏览器的,因此即使页面重新加载,数据也不会丢失。
```javascript
// 存储数据
localStorage.setItem('session_data', session['data']);
// 跳转页面
window.location.href = '/redirect-page';
// 读取数据
var sessionData = localStorage.getItem('session_data');
```
2. 使用表单提交数据
可以将需要传递到下一个页面的数据存储在表单中,然后使用表单提交跳转到下一个页面。在下一个页面中,可以使用服务器端语言来获取表单中提交的数据。
```html
<!-- 存储数据 -->
<form method="post" action="/redirect-page">
<input type="hidden" name="session_data" value="{{ session['data'] }}">
<button type="submit">跳转</button>
</form>
<!-- 读取数据 -->
<p>{{ request.form['session_data'] }}</p>
```
在上述代码中,将需要传递到下一个页面的数据存储在表单的隐藏域中,然后使用表单提交跳转到下一个页面。在下一个页面中,使用服务器端语言来获取表单中提交的数据。这种方法的优点是可以支持所有浏览器,缺点是需要在服务器端编写额外的代码。
阅读全文