使用 Axios 将 MSAL 令牌发送到后端
Sending a MSAL token to backend using Axios
我正在尝试发送之前从 JWT 令牌解码的用户 ID(连同用户输入的数据)。不幸的是,在我尝试发送它的那一刻,我在后端收到一个异常,说请求数组中的数据为空:
Microsoft.EntityFrameworkCore.DbUpdateException: An error occurred while updating the entries. See the inner exception for details.
---> Microsoft.Data.SqlClient.SqlException (0x80131904): Cannot insert the value NULL into column 'Approver1lvl', table 'Requests'; column does not allow nulls. INSERT fails.
根据我在浏览器中看到的控制台日志信息判断,令牌已正确解码。所以,这让我觉得 customInstance.post 部分有错误。
这是我的代码:
export default function NewRequest() {
const [userData, setUserData] = useState({
firstName: "",
surname: "",
co: "",
homeAddress: "",
postCode: "",
city: "",
country: "",
phonePrefix: "",
phoneNumber: "",
email: "",
approver1lvl: "",
employeeId: "",
userId: ""
});
const handleSubmit = () => {
var token = localStorage.getItem("msal.idtoken");
var jwt = jwt_decode(token);
const {
firstName,
surname,
co,
homeAddress,
postCode,
city,
country,
phonePrefix,
phoneNumber,
email,
approver1lvl,
employeeId,
date,
} = userData;
const user = {
firstName,
surname,
co,
homeAddress,
postCode,
city,
country,
phonePrefix,
phoneNumber,
email,
approver1lvl,
employeeId,
birth,
};
customInstance.post("Request", {user, userId: jwt.oid}).then((response) => {});
};
有谁知道如何解决这个问题?
编辑:浏览器错误截图:
EDIT2:我已经使用 swagger 成功发送了一个 POST,它看起来像这样:
我在Swagger中看到userId和email是同级别的,phone ...,我觉得应该是这样的:
export default function NewRequest() {
const [userData, setUserData] = useState({
firstName: "",
surname: "",
co: "",
homeAddress: "",
postCode: "",
city: "",
country: "",
phonePrefix: "",
phoneNumber: "",
email: "",
approver1lvl: "",
employeeId: "",
userId: ""
});
const handleSubmit = () => {
var token = localStorage.getItem("msal.idtoken");
var jwt = jwt_decode(token);
const {
firstName,
surname,
co,
homeAddress,
postCode,
city,
country,
phonePrefix,
phoneNumber,
email,
approver1lvl,
employeeId,
date,
} = userData;
const user = {
firstName,
surname,
co,
homeAddress,
postCode,
city,
country,
phonePrefix,
phoneNumber,
email,
approver1lvl,
employeeId,
birth,
};
customInstance.post("Request", {...user, userId: jwt.oid}).then((response) => {});
};
我正在尝试发送之前从 JWT 令牌解码的用户 ID(连同用户输入的数据)。不幸的是,在我尝试发送它的那一刻,我在后端收到一个异常,说请求数组中的数据为空:
Microsoft.EntityFrameworkCore.DbUpdateException: An error occurred while updating the entries. See the inner exception for details. ---> Microsoft.Data.SqlClient.SqlException (0x80131904): Cannot insert the value NULL into column 'Approver1lvl', table 'Requests'; column does not allow nulls. INSERT fails.
根据我在浏览器中看到的控制台日志信息判断,令牌已正确解码。所以,这让我觉得 customInstance.post 部分有错误。
这是我的代码:
export default function NewRequest() {
const [userData, setUserData] = useState({
firstName: "",
surname: "",
co: "",
homeAddress: "",
postCode: "",
city: "",
country: "",
phonePrefix: "",
phoneNumber: "",
email: "",
approver1lvl: "",
employeeId: "",
userId: ""
});
const handleSubmit = () => {
var token = localStorage.getItem("msal.idtoken");
var jwt = jwt_decode(token);
const {
firstName,
surname,
co,
homeAddress,
postCode,
city,
country,
phonePrefix,
phoneNumber,
email,
approver1lvl,
employeeId,
date,
} = userData;
const user = {
firstName,
surname,
co,
homeAddress,
postCode,
city,
country,
phonePrefix,
phoneNumber,
email,
approver1lvl,
employeeId,
birth,
};
customInstance.post("Request", {user, userId: jwt.oid}).then((response) => {});
};
有谁知道如何解决这个问题?
编辑:浏览器错误截图:
EDIT2:我已经使用 swagger 成功发送了一个 POST,它看起来像这样:
我在Swagger中看到userId和email是同级别的,phone ...,我觉得应该是这样的:
export default function NewRequest() {
const [userData, setUserData] = useState({
firstName: "",
surname: "",
co: "",
homeAddress: "",
postCode: "",
city: "",
country: "",
phonePrefix: "",
phoneNumber: "",
email: "",
approver1lvl: "",
employeeId: "",
userId: ""
});
const handleSubmit = () => {
var token = localStorage.getItem("msal.idtoken");
var jwt = jwt_decode(token);
const {
firstName,
surname,
co,
homeAddress,
postCode,
city,
country,
phonePrefix,
phoneNumber,
email,
approver1lvl,
employeeId,
date,
} = userData;
const user = {
firstName,
surname,
co,
homeAddress,
postCode,
city,
country,
phonePrefix,
phoneNumber,
email,
approver1lvl,
employeeId,
birth,
};
customInstance.post("Request", {...user, userId: jwt.oid}).then((response) => {});
};