2017-11-06 57 views
0

私はVuejsを使用してブラウザアドオンを構築し、Laravel Mixをビルドプロセスとして使用しました。CSPで 'unsafe-eval'を使用しないVuejsブラウザ拡張

私のvueテンプレートはすべて単一のファイルコンポーネントであり、すべてが完全に正常です...私のアドオンマニフェストのCSPから 'unsafe-eval'を削除するまでは。 Firefoxがエラーを示しています。

Content Security Policy: The page's settings blocked the loading of a resource...Source: call to eval() or related function blocked by CSP.

LaravelミックスのWebPACKとVUE-ローダーを使用していますが、私はこれが作成するバンドルがCSPに準拠しているという印象の下にありました。

私は構築されたJSを見てきましたが、eval()への呼び出しはないようですが、問題の原因と思われるnew Function()コールがあります。

私はここで何かが欠けていますか?

答えて

1

私は単純なものがありませんでした。

基本的に私はとても気に入りの実行時のビルドを使用するようにWebPACKのを構成するために必要な:ルートコンポーネントではなく、HTML要素を使用してVUEインスタンス化後

mix.webpackConfig({ 
    resolve: { 
     alias: { 
      'vue$': 'vue/dist/vue.runtime.js' 
     } 
    } 
}); 

const root = require('my-root-component.vue'); 
const app = new Vue({ 
    el: '#app', 
    render: createElement => createElement(root), 
}); 

私が得ましたここで答えます:https://github.com/JeffreyWay/laravel-mix/issues/1052

+0

デフォルトでは、webpackはランタイムファイルのみを選択します。第2に、webpack自体がtry catchブロックで 'eval'メソッドを使用するため、ランタイムへのエイリアスを定義した後でもevalの問題が発生します。 webpackでもhttps://github.com/webpack/webpack/issues/5627で未解決の問題があります –

関連する問題