window.location.href携带session跳转
时间: 2023-11-21 09:56:19 浏览: 35
可以通过在URL中添加参数的方式来携带session跳转。具体步骤如下:
1.在跳转前将session数据存储在URL参数中,例如:
```javascript
var sessionId = '<%= session.getId() %>';
window.location.href = 'http://example.com/targetPage?sessionId=' + sessionId;
```
2.在目标页面中获取URL参数中的session数据,并将其存储在session中,例如:
```java
String sessionId = request.getParameter("sessionId");
HttpSession session = request.getSession();
session.setAttribute("sessionId", sessionId);
```
3.在目标页面中使用session数据,例如:
```java
HttpSession session = request.getSession();
String sessionId = (String) session.getAttribute("sessionId");
```
另外,也可以将重定向操作放到后台去做,这样页面就不会创建新的httpContext,session数据就能获取到了。
相关问题
window.location.href shiro过滤
根据提供的引用内容,window.location.href是JavaScript中的一个属性,用于获取或设置窗口中当前显示文档的URL。在这里,它被用于控制页面的跳转。而Shiro是一个Java安全框架,可以用于身份验证、授权、加密等。在这里,它被用于过滤请求并控制用户访问权限。具体来说,可以通过Shiro的配置文件ShiroConfig中的setSuccessUrl方法来设置用户登录成功后跳转的页面。如果将该方法注释掉,则可以通过window.location.href来控制页面的跳转。
至于如何设置自定义过滤器重定向session过期、使用websocket重定向以及设置ajax全局过滤,这些都是具体的实现方式,需要根据具体情况进行选择和实现。可以参考相关文档或者查找相关资料进行学习和实践。
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 ]