【发布时间】:2022-01-18 03:32:19
【问题描述】:
我有一个在 MEVN 堆栈中构建的项目,可以在本地正常工作,我在 Heroku 中成功部署了我的后端,并使用 Postman 对其进行了测试,一切正常,但是当我尝试使用我的客户端(本地)登录时,我有一个“GET https://invoicing-wmb.herokuapp.com/api/user401(未经授权)”。知道有什么问题吗?...
此外,我一直在使用 console.log("") 进行测试,并且代码在用户中的这一行之前一直有效:
const claims = jwt.verify(cookie, 'secret')
注意:唯一不起作用的是用户身份验证,其他一切正常。
这是后端的mi index.js。
const express = require('express')
const mongoose = require('mongoose')
const cors = require('cors')
const cookieParser = require('cookie-parser')
mongoose.set('useCreateIndex', true)
mongoose.connect('mongodb+srv://markselin:PASSWORD123@cluster0.uaau3.mongodb.net/myFirstDatabase?retryWrites=true&w=majority', {
useNewUrlParser: true,
useUnifiedTopology: true,
useCreateIndex: true
}, () => {
console.log('connected to the database')
})
const routes = require('./routes/routes')
app = express()
app.use(cookieParser())
app.use(cors({
credentials: true,
origin: ['https://invoicing-wmb.herokuapp.com', 'http://localhost:8080'] //CLOUD
}))
app.use(express.json())
app.use('/api', routes)
//testing main /
app.get('/', function(peticion, respuesta){
respuesta.send('WECOME TO OUR API [WBM]')
})
app.get('/api', function(peticion, respuesta){
respuesta.send('INVOICING API [WMB]')
})
app.listen(process.env.PORT || 8000)
这是我在 router.js 中的用户
router.get('/user', async (req, res) => {
try {
const cookie = req.cookies['jwt']
const claims = jwt.verify(cookie, 'secret')
if (!claims) {
res.send({message:'NO AUTENTICADO'})
}
const user = await User.findOne({_id: claims._id})
const {pass, ...data} = await user.toJSON()
console.log('AUTENTICADO'+data)
res.json(data)
} catch (e) {
return res.status(401).send({
message: 'unauthenticated'
})
}
})
客户端登录方式
methods: {
async handleSubmit() {
try {
const respons = await axios.post("login", {
email: this.email,
pass: this.pass,
});
localStorage.setItem("token", respons.data.token);
const response = await axios.get("user");
this.$store.dispatch("user", response.data);
this.$router.push({name:'Inicio'})
} catch (e) {
console.log(e)
}
},
和 axios.js
import axios from 'axios'
axios.defaults.baseURL = 'https://invoicing-wmb.herokuapp.com/api/' //CLOUD
axios.defaults.headers.common['Authorization'] = 'Bearer' + localStorage.getItem('token')
axios.defaults.withCredentials = true;
【问题讨论】:
-
如果那是您实际的 MongoDB 连接 URI,请将其更改为
[redacted]或其他名称。 -
不,不是???但感谢您的推荐。
标签: node.js heroku jwt postman