Angular Apollo 错误处理
Angular Apollo Error Handling
大家好,我有点卡在 apollo-angular 和 apollo-link-error 的问题上。我尝试了几种不同的方法,但似乎无法在我的 angular 网络应用程序中捕获任何客户端错误。我在下面发布了我的尝试。任何建议或额外的眼睛将不胜感激。
基本上我要做的就是在发生错误时提示我的用户有关问题。如果有人有 apollo-link-error 以外的其他 npm 包,我洗耳恭听。
尝试 1:
export class AppModule {
constructor (apollo: Apollo, httpLink: HttpLink) {
apollo.create({
link: httpLink.create({
uri: 'http://localhost:8080/graphql'
}),
cache: new InMemoryCache()
});
const error = onError(({ networkError }) => {
const networkErrorRef:HttpErrorResponse = networkError as HttpErrorResponse;
if (networkErrorRef && networkErrorRef.status === 401) {
console.log('Prompt User', error);
}
});
}
}
尝试 2:
export class AppModule {
constructor (apollo: Apollo, httpLink: HttpLink) {
apollo.create({
link: httpLink.create({
uri: 'http://localhost:8080/graphql'
}),
cache: new InMemoryCache()
});
const error = onError(({networkError}) => {
if (networkError.status === 401) {
console.log('Prompt User', error);
}
});
}
}
尝试 3:
export class AppModule {
constructor (apollo: Apollo, httpLink: HttpLink) {
apollo.create({
link: httpLink.create({
uri: 'http://localhost:8080/graphql'
}),
cache: new InMemoryCache()
});
const link = 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}`);
});
}
}
您可以将 apollo-link-error
视为中间件,因此您必须将其添加到 apollo 客户端的抓取过程中。
意味着你必须创建另一个 apollo link,它结合了 http 和错误 link:
import { ApolloLink } from 'apollo-link';
import { HttpLink } from 'apollo-link-http';
import { onError } from 'apollo-link-error';
...
const errorLink = 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}`);
});
}
}
const httpLink = new HttpLink({
uri: "http://localhost:8080/graphql"
});
const httpLinkWithErrorHandling = ApolloLink.from([
errorLink,
httpLink,
]);
apollo.create({
link: httpLinkWithErrorHandling,
cache: new InMemoryCache()
});
...
另一个可能的解决方案:
import { HttpLink } from 'apollo-link-http';
import { onError } from 'apollo-link-error';
...
const errorLink = 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}`);
});
}
}
const link = httpLink.create({
uri: environment.applications.mAPI.adminEndPoint,
});
apollo.create({
link: errorLink.concat(link),
cache: new InMemoryCache()
});
...
大家好,我有点卡在 apollo-angular 和 apollo-link-error 的问题上。我尝试了几种不同的方法,但似乎无法在我的 angular 网络应用程序中捕获任何客户端错误。我在下面发布了我的尝试。任何建议或额外的眼睛将不胜感激。
基本上我要做的就是在发生错误时提示我的用户有关问题。如果有人有 apollo-link-error 以外的其他 npm 包,我洗耳恭听。
尝试 1:
export class AppModule {
constructor (apollo: Apollo, httpLink: HttpLink) {
apollo.create({
link: httpLink.create({
uri: 'http://localhost:8080/graphql'
}),
cache: new InMemoryCache()
});
const error = onError(({ networkError }) => {
const networkErrorRef:HttpErrorResponse = networkError as HttpErrorResponse;
if (networkErrorRef && networkErrorRef.status === 401) {
console.log('Prompt User', error);
}
});
}
}
尝试 2:
export class AppModule {
constructor (apollo: Apollo, httpLink: HttpLink) {
apollo.create({
link: httpLink.create({
uri: 'http://localhost:8080/graphql'
}),
cache: new InMemoryCache()
});
const error = onError(({networkError}) => {
if (networkError.status === 401) {
console.log('Prompt User', error);
}
});
}
}
尝试 3:
export class AppModule {
constructor (apollo: Apollo, httpLink: HttpLink) {
apollo.create({
link: httpLink.create({
uri: 'http://localhost:8080/graphql'
}),
cache: new InMemoryCache()
});
const link = 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}`);
});
}
}
您可以将 apollo-link-error
视为中间件,因此您必须将其添加到 apollo 客户端的抓取过程中。
意味着你必须创建另一个 apollo link,它结合了 http 和错误 link:
import { ApolloLink } from 'apollo-link';
import { HttpLink } from 'apollo-link-http';
import { onError } from 'apollo-link-error';
...
const errorLink = 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}`);
});
}
}
const httpLink = new HttpLink({
uri: "http://localhost:8080/graphql"
});
const httpLinkWithErrorHandling = ApolloLink.from([
errorLink,
httpLink,
]);
apollo.create({
link: httpLinkWithErrorHandling,
cache: new InMemoryCache()
});
...
另一个可能的解决方案:
import { HttpLink } from 'apollo-link-http';
import { onError } from 'apollo-link-error';
...
const errorLink = 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}`);
});
}
}
const link = httpLink.create({
uri: environment.applications.mAPI.adminEndPoint,
});
apollo.create({
link: errorLink.concat(link),
cache: new InMemoryCache()
});
...