如何使用 then-yield 为模块异步读取文件
How to read file asynchronously for module with then-yield
我正在尝试加载用于 koa-jsonwebtoken 的秘密。
这是我的 koa 服务器的相关位:
import jwt, { fromAuthorizationHeader } from 'koa-jsonwebtoken';
import {serverCredentials} from './auth'
//...
console.log('loaded serverCredentials' + JSON.stringify(serverCredentials))
app.use(jwt({ secret: serverCredentials.shared, extractToken: fromAuthorizationHeader }));
我的授权是:
import ty from 'then-yield'
import md5 from 'md5'
import Promise from 'bluebird'
const fs = Promise.promisifyAll(require('fs'));
const serverCredentials = ty.spawn(function* () {
let src
try {
console.log('trying')
src = yield fs.readFileAsync('./serverCredentials.json','utf8')
} catch(e) {
console.error('Error when opening serverCredentials file: ' + e.message);
throw e
}
console.log('serverCredentials: ' + src)
return JSON.parse(src)
})
export {serverCredentials}
但我的日志显示:
trying
loaded serverCredentials{"isFulfilled":false,"isRejected":false}
而不是服务器密钥。
serverCredentials
是对您的 JSON-parsed 对象的承诺。您需要等待它:
import jwt, { fromAuthorizationHeader } from 'koa-jsonwebtoken';
import {serverCredentials as credentialsPromise} from './auth';
credentialsPromise.then(serverCredentials => {
console.log('loaded serverCredentials' + JSON.stringify(serverCredentials))
app.use(jwt({secret: serverCredentials.shared, extractToken: fromAuthorizationHeader}));
});
我正在尝试加载用于 koa-jsonwebtoken 的秘密。
这是我的 koa 服务器的相关位:
import jwt, { fromAuthorizationHeader } from 'koa-jsonwebtoken';
import {serverCredentials} from './auth'
//...
console.log('loaded serverCredentials' + JSON.stringify(serverCredentials))
app.use(jwt({ secret: serverCredentials.shared, extractToken: fromAuthorizationHeader }));
我的授权是:
import ty from 'then-yield'
import md5 from 'md5'
import Promise from 'bluebird'
const fs = Promise.promisifyAll(require('fs'));
const serverCredentials = ty.spawn(function* () {
let src
try {
console.log('trying')
src = yield fs.readFileAsync('./serverCredentials.json','utf8')
} catch(e) {
console.error('Error when opening serverCredentials file: ' + e.message);
throw e
}
console.log('serverCredentials: ' + src)
return JSON.parse(src)
})
export {serverCredentials}
但我的日志显示:
trying
loaded serverCredentials{"isFulfilled":false,"isRejected":false}
而不是服务器密钥。
serverCredentials
是对您的 JSON-parsed 对象的承诺。您需要等待它:
import jwt, { fromAuthorizationHeader } from 'koa-jsonwebtoken';
import {serverCredentials as credentialsPromise} from './auth';
credentialsPromise.then(serverCredentials => {
console.log('loaded serverCredentials' + JSON.stringify(serverCredentials))
app.use(jwt({secret: serverCredentials.shared, extractToken: fromAuthorizationHeader}));
});