個人博客 地址:http://www.wenhaofan.com/article/20190321183709
介紹
在做單點登錄時,后端需要根據cookie獲取登錄用戶,由於前端項目使用了Nuxt做SSR,所以前端項目服務端使用Axios發送的接口請求中沒有攜帶瀏覽器的cookie,這樣后端項目獲取不到cookie就一直處於未登錄的狀態,所以需要在Axios請求中設置請求頭內容,添加瀏覽器端傳來的cookie值,這里使用Nuxt插件的方法封裝Axios,簡化操作流程
創建插件
1.在plugins目錄下新建axios-plugin.js
2.添加如下代碼
import axios from 'axios'
//開啟瀏覽器端cookie傳遞
axios.defaults.withCredentials=true
const EDU_SERVER_API='http://127.0.0.1/api/v2';
let options = {};
options.baseURL = EDU_SERVER_API
let ax = {
options:options,
get: (req,url) => {
options.headers = {
"Cookie": req.headers.cookie+";"
}
url=options.baseURL+url;
return axios.get(url,options);
}
}
// 為了在 asyncData 方法中使用
export default ({ app }, inject) => {
// Set the function directly on the context.app object
app.$global = {
ax:ax
}
};
3.在Nuxt.config.js中新增plugins,新增后如下
plugins: [
'@/plugins/global',
{
src:'@/plugins/element-ui',
ssr: true,
},
'@/plugins/axios-plugin'
],
AsyncData中使用
代碼如下
export default {
async asyncData(params) {
return params.app.$global.ax.get(params.req, '/user/').then(res => {
return {user: res.data.user};
})
}
}
