- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已经配置并设置了一个功能齐全的 express-nextjs-graphql-apollo 应用程序,它可以登录/注销用户,并且完美地执行 CRUD。最后也是非常重要的一步是在客户端显示错误消息。
到目前为止,我只在控制台中收到此红色错误:POST http://localhost:3000/graphql 500(内部服务器错误)
例如,登录表单验证。当没有提供输入时,它应该得到一个无效的输入错误消息,或者如果电子邮件格式不正确,则 E-Mail is invalid
。
以下变异代码在 graphql localhost:3000/graphql
中测试:
mutation {
login(userInput: {email:"" password:""}){
userId
}
}
返回下面的消息。我实际上希望这条消息显示在客户端上。
{
"errors": [
{
"message": "Please provide input.",
"locations": [
{
"line": 2,
"column": 3
}
],
"path": [
"login"
]
}
],
"data": null
}
我还尝试在带有 onError 的 Mutation 组件内的客户端上显示错误消息:
onError={error => {
console.log("ERROR in SigninBox component ", error);
}}
仅在控制台中显示此错误消息:Response not successful: Received status code 500
这就是我在服务器上设置 'express-graphql'
包的方式:
server.use(
"/graphql",
graphqlHTTP({
schema: graphQlSchema,
rootValue: graphQlResolvers,
graphiql: true,
customFormatErrorFn(err) {
if (!err.originalError) {
return err;
}
const data = err.originalError.data;
const message = err.message || "An error occurred.";
const code = err.originalError.code || 500;
return {
message: message,
status: code,
data: data
};
}
})
);
登录解析器:
login: async ({ userInput }) => {
if (
validator.isEmpty(userInput.email) ||
validator.isEmpty(userInput.password)
) {
throw new Error("Please provide input.");
}
if (!validator.isEmail(userInput.email)) {
throw new Error("E-Mail is invalid.");
}
if (
validator.isEmpty(userInput.password) ||
!validator.isLength(userInput.password, { min: 5 })
) {
throw new Error("Password too short!");
}
const user = await User.findOne({ email: userInput.email });
if (!user) {
const error = new Error("User does not exist!");
error.code = 404;
throw error;
}
const isEqual = await bcrypt.compare(userInput.password, user.password);
if (!isEqual) {
throw new Error("Password is incorrect!");
}
const token = jwt.sign(
{ userId: user.id, email: user.email },
"somesupersecretkey",
{
expiresIn: 1000
}
);
return { userId: user.id, token: token, tokenExpiration: 1 };
}
客户端:
import { Mutation, withApollo } from "react-apollo";
import gql from "graphql-tag";
import redirect from "../lib/redirect";
import { setCookie } from "../helpers/cookie";
const SIGN_IN = gql`
mutation login($email: String!, $password: String!) {
login(userInput: { email: $email, password: $password }) {
token
}
}
`;
const Signin = ({ client }) => {
let email, password;
return (
<Mutation
mutation={SIGN_IN}
onCompleted={data => {
setCookie("token", data.login.token);
client.cache.reset().then(() => {
redirect({}, "/admin");
});
}}
onError={error => {
console.log("ERROR in SigninBox ", error);
}}
>
{(login, { data, error }) => (
<div>
<form
onSubmit={e => {
e.preventDefault();
e.stopPropagation();
login({
variables: {
email: email.value,
password: password.value
}
});
email.value = password.value = "";
}}
>
<div>
<h1>Admin Page Login</h1>
</div>
<div className="form-label-group">
<input
className={`form-control ${error ? "is-invalid" : ""}`}
name="email"
id="inputEmail"
placeholder="Email"
ref={node => {
email = node;
}}
/>
<label htmlFor="inputEmail">Email address</label>
{error && (
<div className="invalid-feedback">
No user found with that information.
</div>
)}
</div>
<div>
<input
name="password"
id="inputPassword"
placeholder="Password"
ref={node => {
password = node;
}}
type="password"
/>
<label htmlFor="inputPassword">Password</label>
</div>
<button type="submit">Login</button>
</form>
</div>
)}
</Mutation>
);
};
export default withApollo(SignIn);
我也试过这个 onError 检查:
onError={({ graphQLErrors, networkError }) => {
if (graphQLErrors)
graphQLErrors.map(({ message, locations, path }) =>
console.log(
`[GraphQL error]: Message: ${message}, Location: ${locations}, Path: ${path}`
)
);
if (networkError) console.log(`[Network error]: ${networkError}`);
}}
基本上返回了相同的错误消息:[网络错误]: ServerError: 响应不成功: 收到状态代码 500
我的目标是显示我通常会在 graphql localhost:3000/graphql
中收到的来 self 的解析器的消息,例如:E-Mail is invalid
, 请提供输入。
或等等。如何将此消息
发送到客户端 onError 处理程序?
最佳答案
经过一些研究我意识到错误本身是一个对象
onError={error => {
console.log("ERROR in SigninBox ", { error });
}}
错误信息存储在error.networkError.result.errors[0].message
关于reactjs - Apollo 客户端不显示错误信息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56195999/
这是关于非标准属性的。 https://facebook.github.io/react/docs/tags-and-attributes.html 在 react 中我做了这个: React.cr
我制作了 2 个组件:1)内容(使用 fetch() 显示数据)2)分页(共5页,每页16个对象) 我创建了 2 个状态变量,分别称为 start:0 和 end:16。现在,每当用户单击页码时,我都
我们正在使用 ReactJS 创建一个搜索前端。要求是当用户单击文档名称时,该文档必须在嵌入式查看器中打开。有人为此使用过任何 ReactJS 组件吗?否则,我应该使用 JQuery 查看器组件吗?请
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 1 年前。
我现有的项目: 前端框架 - PHP Codeigniter 和 PHP Laravel 后端框架 - JAVA Springboot 我正在尝试将前端框架更改为 ReactJS。我想知道与 Reac
我有一个实现刷新授权 token 的方案。在这种情况下,我为每种操作(发布、获取、删除)实现了一个通用操作,并使用参数调用它们。 export function Get(param) { return
我现在有 { _this.setState({startDate: input})}}/> 无论我一直在改变什么(onChange 部分到 ref 等等),当我 console.log 我的状态时,
我在两个不同的文件中有两个单独的组件 组件A 和 组件B 我在 中有一个按钮组件B 现在我想测试当 中的特定按钮时组件B 被点击,组件A 应呈现如下: import { render, screen,
我有一个包含几个问题的表格。一些问题有一组子问题。 这些是使用以下代码呈现的。 { Object.keys(this.props.moduleDetails.questions).map(
我有两个组件。第一个状态初始化: import React from 'react'; class One extends React.Component { constructor(prop
我的项目是一个对象数组,我只获取名称并在 3 in 3 的屏幕上渲染,使用“下一个”和“上一个”按钮更改名称,并且可以过滤字母。 我想要添加一个新值,在输入中键入并单击按钮添加。 我的代码按钮: ad
我有一个组件实例,应该从不同的地方更新。如何从其他几个组件中更新此组件的 props? class ParentComponent extends React.Component { ...
我想问,是否可以基于变量返回一个组件,我的想法是否可以: var location = this.props.location // Eg. Asia,Australia 我的问题是我需要单独手动导
有没有办法在渲染后立即选择要覆盖的文本?我的意思是选择 - 最佳答案 您可以尝试使用两种方法.focus和.select .focus() method sets focus on the speci
我渲染了以下内容: 这是事件处理程序: handleCompanySubmit(event) { console.log("company submit") e
作为ReactJS的初学者,我现在使用出色的ReactJS Datepicker。有关我的自定义日期格式的问题: 我没有找到任何文档来解释所有可能性,例如M是月份,MM是2个字母的月份,依此类推。(我
我创建了一个表并正在对其进行过滤,但是当我清除搜索查询时,表数据不会显示,并且表会卡在查询结果上。SearchBox 是文本框,TableData 是表格,在 Container 中我正在更改 Sea
我在表格设置中有图标,这样当单击图标时,会呈现不同的图标。现在这工作正常,但我想为我单击的行中的特定行重新呈现不同的图标,而不是在每一行中重新呈现不同的图标。不知道我将如何去做这件事。这是我的代码:
我正在尝试使用 React 构建一个简单的应用程序,它有两个组件,一个嵌入另一个组件。子组件是一个收缩的菜单,单击它时,它会展开。我希望能够在单击父元素或子元素失去焦点时重新收缩它。 这是父组件的样子
我需要知道 REACT JS 或 HTML5 中是否有任何 API 可以提供用户不活动时自动注销的功能。我的代码如下,我不知道出了什么问题,它给了我错误 startTimer 未定义和不必要的绑定(b
我是一名优秀的程序员,十分优秀!