React Developer Tools、Redux DevTools 能够给开发人员在研发阶段调试程序带来极大的方便。 可是,不少人忽略了一点:上了生产环境后,把一些代码细节轻易让外部人员获取,并非好事。javascript
解决方案就是:生产环境下,将DevTools禁止使用。java
如下是实现的代码react
// 项目入口文件index.tsx
import {
disableReactDevTools
} from '@utils/js/other';
if(process.env.NODE_ENV == 'production'){
disableReactDevTools();
}
复制代码
// @utils/js/other.ts
export const disableReactDevTools = (): void => {
const noop = (): void => undefined;
const DEV_TOOLS = (window as any).__REACT_DEVTOOLS_GLOBAL_HOOK__;
if (typeof DEV_TOOLS === 'object') {
for (const [key, value] of (<any>Object).entries(DEV_TOOLS)) { DEV_TOOLS[key] = typeof value === 'function' ? noop : null; } } }; 复制代码
禁止思路以下:git
window.__REACT_DEVTOOLS_GLOBAL_HOOK__.inject = function () {}
复制代码
这样能够阻止devtools访问React上下文github
window.__REACT_DEVTOOLS_GLOBAL_HOOK__
下挂载的方法,将其重置为空函数。windwo.__REACT_DEVTOOLS_GLOBAL_HOOK__
的,因此要进行安全防御。综合以上3点,就能够得出disableReactDevTools
方法。redux
另外,只在生产环境禁止,则须要读取process.env.NODE_ENV
的值,进行判断。符合要求,则执行disableReactDevTools
方法。浏览器
Redux DevTools的做者作得比较全面,已经给出了标准的解决方案。安全
具体实现步骤以下:函数
'process.env.NODE_ENV': JSON.stringify('production')
redux-devtools-extension/developmentOnly
引入方法如下是个人项目代码片段:oop
import {
composeWithDevTools
} from 'redux-devtools-extension/developmentOnly';
// other code...
const store = createStore(
rootReducer,
composeWithDevTools(middlewareEnhancer)
);
// other code...
复制代码
喜欢我文章的朋友,能够经过如下方式关注我: