SyntaxError: Unexpected end of JSON input - CryptoJS
13/02/2024
0
Estou recebendo esse erro ao fazer solicitações via axios para meu servidor express, onde passo um payload criptografado e tento descriptografá-lo no backend, porém, sem resultados.
Abaixo estão os códigos de front-end e back-end
OBS: No meu payload, a string está sendo passada normalmente, porém, no backend, meu "req.body" simplesmente não captura a string de forma alguma, e por conta disso não consigo passá-la para minha função "decrypt", e então recebo esse erro.
Alguém pode me ajudar? Não consigo encontrar nada na internet sobre isso.
//Front
export const cryptoLogin = defineStore(''cryptologin'', {
actions: {
encryptData(data) {
const ciphertext = CryptoJS.AES.encrypt(JSON.stringify(data), ''fJ7#yM1(xY6#jR6:'').toString();
return ciphertext;
}
}
})
async loginSend() {
const dados = [{
email: this.email,
password: this.password
}]
await axios.post(''http://localhost:3000/login'', cryptoLogin().encryptData(dados))
.then((Response) => {
const token = Response.data.token
localStorage.setItem(''x-access-token'', token)
if (Response.data.success) {
this.$router.push(''/index'')
this.$q.notify({
color: ''green-4'',
textColor: ''white'',
icon: ''cloud_done'',
message: ''Login Autorizado''
})
}
else {
this.reset()
this.$q.notify({
color: ''red'',
textColor: ''white'',
icon: ''warning'',
message: ''Credenciais inválidas''
})
}
})
},
//Back
function decrypt(data) {
var bytes = CryptoJS.AES.decrypt(data, ''fJ7#yM1(xY6#jR6:'');
var decryptedData = JSON.parse(bytes.toString(CryptoJS.enc.Utf8));
return decryptedData
}
module.exports = decrypt
app.post(''/login'', async (req, res) => {
const data = req.body
console.log(data);
const decryptedData = await decrypt(data)
const { email, password } = decryptedData
const logado = await Cliente.findOne({ where: { email, password } })
const id = await Cliente.findAll({ attributes: [''id''], where: { email, password } })
if (logado) {
const token = jwt.sign({ userId: id[0].id }, segredo, { expiresIn: 86400 })
res.json({ success: true, token })
}
else {
res.status(401).end()
}
})
Abaixo estão os códigos de front-end e back-end
OBS: No meu payload, a string está sendo passada normalmente, porém, no backend, meu "req.body" simplesmente não captura a string de forma alguma, e por conta disso não consigo passá-la para minha função "decrypt", e então recebo esse erro.
Alguém pode me ajudar? Não consigo encontrar nada na internet sobre isso.
//Front
export const cryptoLogin = defineStore(''cryptologin'', {
actions: {
encryptData(data) {
const ciphertext = CryptoJS.AES.encrypt(JSON.stringify(data), ''fJ7#yM1(xY6#jR6:'').toString();
return ciphertext;
}
}
})
async loginSend() {
const dados = [{
email: this.email,
password: this.password
}]
await axios.post(''http://localhost:3000/login'', cryptoLogin().encryptData(dados))
.then((Response) => {
const token = Response.data.token
localStorage.setItem(''x-access-token'', token)
if (Response.data.success) {
this.$router.push(''/index'')
this.$q.notify({
color: ''green-4'',
textColor: ''white'',
icon: ''cloud_done'',
message: ''Login Autorizado''
})
}
else {
this.reset()
this.$q.notify({
color: ''red'',
textColor: ''white'',
icon: ''warning'',
message: ''Credenciais inválidas''
})
}
})
},
//Back
function decrypt(data) {
var bytes = CryptoJS.AES.decrypt(data, ''fJ7#yM1(xY6#jR6:'');
var decryptedData = JSON.parse(bytes.toString(CryptoJS.enc.Utf8));
return decryptedData
}
module.exports = decrypt
app.post(''/login'', async (req, res) => {
const data = req.body
console.log(data);
const decryptedData = await decrypt(data)
const { email, password } = decryptedData
const logado = await Cliente.findOne({ where: { email, password } })
const id = await Cliente.findAll({ attributes: [''id''], where: { email, password } })
if (logado) {
const token = jwt.sign({ userId: id[0].id }, segredo, { expiresIn: 86400 })
res.json({ success: true, token })
}
else {
res.status(401).end()
}
})
Lucas
Curtir tópico
+ 0
Responder
Posts
17/02/2024
Mikhael
Estou recebendo esse erro ao fazer solicitações via axios para meu servidor express, onde passo um payload criptografado e tento descriptografá-lo no backend, porém, sem resultados.
Abaixo estão os códigos de front-end e back-end
OBS: No meu payload, a string está sendo passada normalmente, porém, no backend, meu "req.body" simplesmente não captura a string de forma alguma, e por conta disso não consigo passá-la para minha função "decrypt", e então recebo esse erro.
Alguém pode me ajudar? Não consigo encontrar nada na internet sobre isso.
//Front
export const cryptoLogin = defineStore(''cryptologin'', {
actions: {
encryptData(data) {
const ciphertext = CryptoJS.AES.encrypt(JSON.stringify(data), ''fJ7#yM1(xY6#jR6:'').toString();
return ciphertext;
}
}
})
async loginSend() {
const dados = [{
email: this.email,
password: this.password
}]
await axios.post(''http://localhost:3000/login'', cryptoLogin().encryptData(dados))
.then((Response) => {
const token = Response.data.token
localStorage.setItem(''x-access-token'', token)
if (Response.data.success) {
this.$router.push(''/index'')
this.$q.notify({
color: ''green-4'',
textColor: ''white'',
icon: ''cloud_done'',
message: ''Login Autorizado''
})
}
else {
this.reset()
this.$q.notify({
color: ''red'',
textColor: ''white'',
icon: ''warning'',
message: ''Credenciais inválidas''
})
}
})
},
//Back
function decrypt(data) {
var bytes = CryptoJS.AES.decrypt(data, ''fJ7#yM1(xY6#jR6:'');
var decryptedData = JSON.parse(bytes.toString(CryptoJS.enc.Utf8));
return decryptedData
}
module.exports = decrypt
app.post(''/login'', async (req, res) => {
const data = req.body
console.log(data);
const decryptedData = await decrypt(data)
const { email, password } = decryptedData
const logado = await Cliente.findOne({ where: { email, password } })
const id = await Cliente.findAll({ attributes: [''id''], where: { email, password } })
if (logado) {
const token = jwt.sign({ userId: id[0].id }, segredo, { expiresIn: 86400 })
res.json({ success: true, token })
}
else {
res.status(401).end()
}
})
Para resolver o erro você precisa que o Content-Type na sua solicitação axios está configurado corretamente para application/jsonAbaixo estão os códigos de front-end e back-end
OBS: No meu payload, a string está sendo passada normalmente, porém, no backend, meu "req.body" simplesmente não captura a string de forma alguma, e por conta disso não consigo passá-la para minha função "decrypt", e então recebo esse erro.
Alguém pode me ajudar? Não consigo encontrar nada na internet sobre isso.
//Front
export const cryptoLogin = defineStore(''cryptologin'', {
actions: {
encryptData(data) {
const ciphertext = CryptoJS.AES.encrypt(JSON.stringify(data), ''fJ7#yM1(xY6#jR6:'').toString();
return ciphertext;
}
}
})
async loginSend() {
const dados = [{
email: this.email,
password: this.password
}]
await axios.post(''http://localhost:3000/login'', cryptoLogin().encryptData(dados))
.then((Response) => {
const token = Response.data.token
localStorage.setItem(''x-access-token'', token)
if (Response.data.success) {
this.$router.push(''/index'')
this.$q.notify({
color: ''green-4'',
textColor: ''white'',
icon: ''cloud_done'',
message: ''Login Autorizado''
})
}
else {
this.reset()
this.$q.notify({
color: ''red'',
textColor: ''white'',
icon: ''warning'',
message: ''Credenciais inválidas''
})
}
})
},
//Back
function decrypt(data) {
var bytes = CryptoJS.AES.decrypt(data, ''fJ7#yM1(xY6#jR6:'');
var decryptedData = JSON.parse(bytes.toString(CryptoJS.enc.Utf8));
return decryptedData
}
module.exports = decrypt
app.post(''/login'', async (req, res) => {
const data = req.body
console.log(data);
const decryptedData = await decrypt(data)
const { email, password } = decryptedData
const logado = await Cliente.findOne({ where: { email, password } })
const id = await Cliente.findAll({ attributes: [''id''], where: { email, password } })
if (logado) {
const token = jwt.sign({ userId: id[0].id }, segredo, { expiresIn: 86400 })
res.json({ success: true, token })
}
else {
res.status(401).end()
}
})
await axios.post('http://localhost:3000/login', cryptoLogin().encryptData(dados), {
headers: {
'Content-Type': 'application/json'
}
})
Pelo que percebi você está usando JSON.stringify antes de criptografar os dados, então faça isso:
const dados = {
email: this.email,
password: this.password
};
await axios.post('http://localhost:3000/login', cryptoLogin().encryptData(dados), {
headers: {
'Content-Type': 'application/json'
}
})
e outra coisa pelo que percebi você está tentando acessar req.body, mas a partir do seu código, parece que você está usando data diretamente. Escreva o seguinte código para acessar data em vez de req.body
app.post('/login', async (req, res) => {
const data = req.body; // ou const data = req.body.data; dependendo da estrutura do seu payload
console.log(data);
// Resto do código...
});
Mas preste atençao na hora que o Express está configurado para analisar JSON. Adicione o middleware express.json() antes das rotas, escreva isso:
const express = require('express');
const app = express();
app.use(express.json());
Espero ter ajudado!
Responder
Gostei + 0
Clique aqui para fazer login e interagir na Comunidade :)