{"id":12237,"date":"2024-01-21T07:00:35","date_gmt":"2024-01-20T22:00:35","guid":{"rendered":"https:\/\/blog.capilano-fw.com\/?p=12237"},"modified":"2024-01-11T03:53:09","modified_gmt":"2024-01-10T18:53:09","slug":"%e3%80%8cchatgpt-%e3%83%95%e3%82%a9%e3%83%bc%e3%83%a0%e6%93%8d%e4%bd%9c%e3%83%87%e3%83%bc%e3%82%bf%e3%80%8d%e3%81%a7%e6%80%a7%e6%a0%bc%e5%88%a4%e5%88%a5%e3%81%97%e3%80%81%e3%83%aa%e3%82%af%e3%83%ab","status":"publish","type":"post","link":"https:\/\/blog.capilano-fw.com\/?p=12237","title":{"rendered":"\u300cChatGPT + \u30d5\u30a9\u30fc\u30e0\u64cd\u4f5c\u30c7\u30fc\u30bf\u300d\u3067\u6027\u683c\u5224\u5225\u3057\u3001\u30ea\u30af\u30eb\u30fc\u30c8\u306b\u5f79\u7acb\u3066\u308b"},"content":{"rendered":"<p>\u3055\u3066\u3055\u3066\u3001\u6628\u4eca\u3088\u304f\u8a00\u308f\u308c\u308b\u306e\u304c\u300c<strong>\u4eba\u624b\u4e0d\u8db3<\/strong>\u300d\u3067\u3059\u3088\u306d\u3002<br \/>\n\u6211\u3005<code>IT<\/code>\u696d\u754c\u3082\u305d\u306e\u4f8b\u306b\u3082\u308c\u305a\u6162\u6027\u7684\u306a\u4eba\u624b\u4e0d\u8db3\u3068\u306a\u3063\u3066\u3044\u308b\u8077\u5834\u3082\u591a\u304b\u3063\u305f\u308a\u3059\u308b\u3093\u3058\u3083\u306a\u3044\u3067\u3057\u3087\u3046\u304b\u3002<\/p>\n<p>\u305f\u3060\u3001\u305d\u306e\u88cf\u3067\u805e\u304b\u308c\u308b\u306e\u304c\u30fb\u30fb\u30fb\u30fb\u30fb\u30fb<\/p>\n<p><strong style=\"font-size: 35px;\">\u30ea\u30af\u30eb\u30fc\u30c8\uff08\u63a1\u7528\uff09\u304c\u5927\u5909<\/strong><\/p>\n<p>\u3053\u308c\u306f\u65e5\u672c\u306e\u52b4\u50cd\u74b0\u5883\u306e\u5f71\u97ff\u3082\u3042\u308b\u3093\u3067\u3057\u3087\u3046\u304c\u3001\u300c<strong>\u96c7\u3063\u305f\u3089\u89e3\u96c7\u3057\u306b\u304f\u3044<\/strong>\u300d\u30b7\u30b9\u30c6\u30e0\u306b\u306a\u3063\u3066\u3044\u308b\u306e\u3067\u3001\u3068\u304f\u306b\u7d4c\u55b6\u8005\u3084\u4eba\u4e8b\u306e\u65b9\u306f\u795e\u7d4c\u3092\u3059\u308a\u6e1b\u3089\u3057\u3066\u3044\u308b\u3053\u3068\u3068\u601d\u3044\u307e\u3059\u3002<\/p>\n<p>\u3067\u3001\u305d\u3046\u8003\u3048\u3066\u3044\u305f\u3089\u3001\u3042\u308b\uff11\u3064\u306e\u30a2\u30a4\u30c7\u30a2\u304c\u6d6e\u304b\u3073\u307e\u3057\u305f\u3002<\/p>\n<p>\u305d\u308c\u306f\u30fb\u30fb\u30fb\u30fb\u30fb\u30fb<\/p>\n<p><strong style=\"font-size: 35px;\">\u30de\u30a6\u30b9\u3084\u3001\u30ad\u30fc\u30dc\u30fc\u30c9\u306e\u52d5\u304d\u3067\u6027\u683c\u3092\u5927\u307e\u304b\u306b\u628a\u63e1\u3059\u308b<\/strong><\/p>\n<p>\u3068\u3044\u3046\u6a5f\u80fd\u3067\u3059\u3002<\/p>\n<p>\u3064\u307e\u308a\u3001\u30a8\u30f3\u30c8\u30ea\u30fc\u30b7\u30fc\u30c8\u3067\u5fd7\u671b\u52d5\u6a5f\u3084\u7d4c\u6b74\u306a\u3069\u3092\u5165\u529b\u3059\u308b\u3068\u304d\u306b\u4ee5\u4e0b\u306e\u3088\u3046\u306a\u30c7\u30fc\u30bf\u3082\u3068\u3063\u3066\u304a\u304d\u4e00\u7dd2\u306b\u30b5\u30fc\u30d0\u30fc\u3078\u9001\u4fe1\u3059\u308b\u3068\u3044\u3046\u6d41\u308c\u3067\u3059\u3002<\/p>\n<ul>\n<li>\u30ad\u30fc\u30dc\u30fc\u30c9\u306e\u30bf\u30a4\u30d4\u30f3\u30b0\u901f\u5ea6<\/li>\n<li>\u30d0\u30c3\u30af\u30b9\u30da\u30fc\u30b9\u3084 Delete \u30ad\u30fc\u306e\u4f7f\u7528\u983b\u5ea6\uff08\u9593\u9055\u3044\u3092\u4fee\u6b63\u3059\u308b\u56de\u6570\uff09<\/li>\n<li>\u5404\u7a2e\u30dc\u30c3\u30af\u30b9\u306b\u5165\u529b\u3057\u305f\u6642\u9593<\/li>\n<\/ul>\n<p>\u203b \u3061\u306a\u307f\u306b\u3053\u3046\u3044\u3063\u305f\u30c7\u30fc\u30bf\u3092\u53d6\u5f97\u3059\u308b\u5834\u5408\u306f\u4e8b\u524d\u306b\u300c<strong>\u64cd\u4f5c\u30c7\u30fc\u30bf\u3092\u53ce\u96c6\u3057\u3066\u3044\u307e\u3059<\/strong>\u300d\u306a\u3069\u306e\u6ce8\u610f\u66f8\u304d\u3084\u540c\u610f\u306f\u5fc5\u8981\u3060\u3068\u601d\u3044\u307e\u3059\u3002\u5ff5\u306e\u305f\u3081\uff09<\/p>\n<p>\u305d\u3053\u3067\u2757<\/p>\n<p>\u4eca\u56de\u306f\u300c<strong>Laravel + Vue 3<\/strong>\u300d\u3092\u4f7f\u3063\u3066\u9001\u4fe1\u8005\u306e\u6027\u683c\u3092\u5927\u307e\u304b\u306b\u628a\u63e1\u3059\u308b\u6a5f\u80fd\u3092\u3064\u304f\u3063\u3066\u307f\u305f\u3044\u3068\u601d\u3044\u307e\u3059\u3002<\/p>\n<p>\u203b \u306a\u304a\u3001\u5f53\u521d\u306f\u30de\u30a6\u30b9\u306e\u79fb\u52d5\u901f\u5ea6\u306a\u3069\u3082\u8003\u3048\u3066\u3044\u305f\u306e\u3067\u3059\u304c\u3001\u8907\u96d1\u306b\u306a\u308a\u3059\u304e\u308b\u306e\u3067\u30ad\u30fc\u30dc\u30fc\u30c9\u64cd\u4f5c\u306e\u307f\u306b\u3057\u307e\u3057\u305f\u3002<\/p>\n<p>\u305c\u3072\u4f55\u304b\u306e\u53c2\u8003\u306b\u306a\u308a\u307e\u3057\u305f\u3089\u5b09\u3057\u3044\u3067\u3059\u3002\ud83d\ude04\u2728<\/p>\n<p style=\"text-align: center;\"><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-full wp-image-3566 aligncenter\" src=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2019\/04\/no_1.png\" alt=\"\" width=\"306\" height=\"320\" srcset=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2019\/04\/no_1.png 306w, https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2019\/04\/no_1-287x300.png 287w\" sizes=\"auto, (max-width: 306px) 100vw, 306px\" \/>\u300c\u30ea\u30b9\u30c6\u30ea\u30f3\u4f7f\u3063\u305f\u3089<br \/>\n\u80c3\u306e\u8abf\u5b50\u307e\u3067\u826f\u304f\u306a\u3063\u305f\uff01<br \/>\n\u5e74\u672b\u306f\u66b4\u98f2\u66b4\u98df\u3059\u308b\u305e\uff08\u7b11\uff09\u300d<\/p>\n<p><strong>\u958b\u767a\u74b0\u5883\uff1a<\/strong> Laravel 10.x\u3001Vue 3\uff08options api\uff09<\/p>\n<h1>ChatGPT \u306e API \u304c\u4f7f\u3048\u308b\u3088\u3046\u306b\u3059\u308b<\/h1>\n<p>\u307e\u305a\u306f\u3001<code>ChatGPT<\/code>\u304c<code>Laravel<\/code>\u304b\u3089\u4f7f\u3048\u308b\u3088\u3046\u306b\u3057\u307e\u3059\u3002<br \/>\n\u4ee5\u4e0b\u306e\u30b3\u30de\u30f3\u30c9\u3067\u30d1\u30c3\u30b1\u30fc\u30b8\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n<pre class=\"code-helper code-helper-3 hljs coffeescript\"><strong>composer <span class=\"hljs-built_in\">require<\/span> openai-php\/laravel<\/strong><\/pre>\n<p>\u30d1\u30c3\u30b1\u30fc\u30b8\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u305f\u3089\u300c<strong>API \u30ad\u30fc<\/strong>\u300d\u3092\u53d6\u5f97\u3057\u3066<code>.env<\/code>\u3078\u30bb\u30c3\u30c8\u3057\u307e\u3059\u3002\u624b\u9806\u306f\u904e\u53bb\u8a18\u4e8b\u3092\u53c2\u8003\u306b\u3057\u3066\u307f\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n<ul>\n<li><a href=\"https:\/\/blog.capilano-fw.com\/?p=11642#OpenAI_API\" target=\"_blank\" rel=\"noopener\">OpenAI \u306e API \u30ad\u30fc\u3092\u53d6\u5f97\u3059\u308b<\/a><\/li>\n<li><a href=\"https:\/\/blog.capilano-fw.com\/?p=11642#OpenAI\" target=\"_blank\" rel=\"noopener\">OpenAI\u306b\u8ab2\u91d1\u767b\u9332\u3059\u308b<\/a><\/li>\n<\/ul>\n<p><strong>.env<\/strong><\/p>\n<div>\n<pre class=\"code-helper code-helper-2 hljs markdown\"><strong>OPENAI<span class=\"hljs-emphasis\">_API_<\/span>KEY=<span class=\"hljs-strong\">****<\/span><span class=\"hljs-strong\">****<\/span><span class=\"hljs-strong\">****<\/span><span class=\"hljs-strong\">****<\/span><span class=\"hljs-strong\">****<\/span><span class=\"hljs-strong\">****<\/span><span class=\"hljs-strong\">****<\/span><span class=\"hljs-strong\">****<\/span><span class=\"hljs-emphasis\">*<\/span><\/strong><\/pre>\n<p>\u203b \u30cf\u30a4\u30d5\u30f3\u306a\u3069\u306e\u6587\u5b57\u304c\u5165\u3063\u3066\u3044\u308b\u5834\u5408\u306f\u30af\u30a9\u30fc\u30c8\u3067\u56f2\u3093\u3060\u307b\u3046\u304c\u3044\u3044\u304b\u3082\u3057\u308c\u307e\u305b\u3093\u3002<\/p>\n<h1>\u30b3\u30f3\u30c8\u30ed\u30fc\u30e9\u30fc\u3092\u3064\u304f\u308b<\/h1>\n<p>\u3067\u306f\u3001\u4ee5\u4e0b\u306e\u30b3\u30de\u30f3\u30c9\u3067\u30b3\u30f3\u30c8\u30ed\u30fc\u30e9\u30fc\u3092\u3064\u304f\u308a\u307e\u3057\u3087\u3046\u3002<\/p>\n<div>\n<pre><strong>php artisan make:controller ApplicationFormController<\/strong><\/pre>\n<p>\u305d\u3057\u3066\u3001<code>app\/Http\/Controllers<\/code>\u306b\u4f5c\u6210\u3055\u308c\u305f\u30d5\u30a1\u30a4\u30eb\u3092\u4ee5\u4e0b\u306e\u3088\u3046\u306b\u3057\u307e\u3059\u3002<\/p>\n<p><strong>app\/Http\/Controllers\/ApplicationFormController.php<\/strong><\/p>\n<div>\n<pre><strong>&lt;?php<\/strong>\r\n\r\n<strong>namespace App\\Http\\Controllers;<\/strong>\r\n\r\n<strong>use Illuminate\\Http\\Request;<\/strong>\r\n<strong>use Illuminate\\Support\\Arr;<\/strong>\r\n<strong>use OpenAI\\Laravel\\Facades\\OpenAI;<\/strong>\r\n\r\n<strong>class ApplicationFormController extends Controller<\/strong>\r\n<strong>{<\/strong>\r\n<strong>    public function create()<\/strong>\r\n<strong>    {<\/strong>\r\n<strong>        return view('application_form.create');<\/strong>\r\n<strong>    }<\/strong>\r\n\r\n<strong>    public function store(Request $request)<\/strong>\r\n<strong>    {<\/strong>\r\n<strong>        \/\/ \u30d0\u30ea\u30c7\u30fc\u30b7\u30e7\u30f3\u306f\u7701\u7565\u3057\u3066\u3044\u307e\u3059<\/strong>\r\n<strong>        \/\/ \u672c\u6765\u306f\u3053\u3053\u3067\u30c7\u30fc\u30bf\u3092\u4fdd\u5b58\uff08\u4eca\u56de\u306f\u7701\u7565\uff09<\/strong>\r\n\r\n<strong>        $typing_data = $request-&gt;typing_data;<\/strong>\r\n\r\n<strong>        $prompt = view('application_form.prompt', [<\/strong>\r\n<strong>            'typing_data' =&gt; $typing_data,<\/strong>\r\n<strong>        ])-&gt;render();<\/strong>\r\n\r\n<strong>        $chatgpt_response = '';<\/strong>\r\n\r\n<strong>        \/\/ \u3054\u6ce8\u610f\uff1a \u6642\u9593\u304c\u304b\u304b\u308b\u5834\u5408\u304c\u3042\u308b\u306e\u3067 PHP \u306e\u30bf\u30a4\u30e0\u30a2\u30a6\u30c8\u8a2d\u5b9a\uff08max_execution_time\uff09\u3092\u7121\u52b9\u306b\u3059\u308b\u304b\u9577\u3081\u306b\u8a2d\u5b9a\u3057\u3066\u304a\u3044\u3066\u304f\u3060\u3055\u3044<\/strong>\r\n\r\n<strong>        try {<\/strong>\r\n\r\n<strong>            $result = OpenAI::chat()-&gt;create([<\/strong>\r\n<strong>                'model' =&gt; 'gpt-4',<\/strong>\r\n<strong>                'messages' =&gt; [<\/strong>\r\n<strong>                    ['role' =&gt; 'user', 'content' =&gt; $prompt],<\/strong>\r\n<strong>                ],<\/strong>\r\n<strong>            ]);<\/strong>\r\n<strong>            $chatgpt_response = Arr::get($result, 'choices.0.message.content');<\/strong>\r\n\r\n<strong>        } catch (\\Exception $e) {<\/strong>\r\n\r\n<strong>            throw $e;<\/strong>\r\n\r\n<strong>        }<\/strong>\r\n\r\n<strong>        return [<\/strong>\r\n<strong>            'status' =&gt; 'success',<\/strong>\r\n<strong>            'chatgpt_response' =&gt; $chatgpt_response, \/\/ \u4eca\u56de\u306f\u30c6\u30b9\u30c8\u306a\u306e\u3067\u3001chatgpt_response \u3092\u30d6\u30e9\u30a6\u30b6\u5074\u3078\u8fd4\u3057\u3066\u3044\u307e\u3059<\/strong>\r\n<strong>        ];<\/strong>\r\n<strong>    }<\/strong>\r\n<strong>}<\/strong><\/pre>\n<p>\u3061\u306a\u307f\u306b\u30b3\u30fc\u30c9\u306e\u4e2d\u3067\u3082\u66f8\u3044\u3066\u3044\u307e\u3059\u304c\u3001\u30bf\u30a4\u30e0\u30a2\u30a6\u30c8\u3059\u308b\u53ef\u80fd\u6027\u304c\u3042\u308b\u306e\u3067<code>php<\/code>\u306e\u5b9f\u884c\u671f\u9593\uff08<strong>max_execution_time<\/strong>\uff09\u306f\u7121\u52b9\u306b\u3059\u308b\u304b\u3001\u9577\u3081\u306b\u8a2d\u5b9a\u3057\u3066\u304a\u304f\u65b9\u304c\u3044\u3044\u3068\u601d\u3044\u307e\u3059\u3002<\/p>\n<\/div>\n<\/div>\n<h1>\u30d3\u30e5\u30fc\uff08\u30d5\u30a9\u30fc\u30e0\u7528\uff09\u3092\u3064\u304f\u308b<\/h1>\n<p>\u3067\u306f\u3001\u30b3\u30f3\u30c8\u30ed\u30fc\u30e9\u30fc\u306e\u4e2d\u306b\u30bb\u30c3\u30c8\u3057\u305f\u30d3\u30e5\u30fc\u3092\u3064\u304f\u308a\u307e\u3059\u3002<br \/>\n\u4ee5\u4e0b\u306e\u30b3\u30de\u30f3\u30c9\u3092\u5b9f\u884c\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n<div>\n<pre><strong>php artisan make:view application_form.create<\/strong><\/pre>\n<p>\u3059\u308b\u3068\u3001<code>resources\/views\/application_form<\/code>\u306b\u30d5\u30a1\u30a4\u30eb\u304c\u4f5c\u6210\u3055\u308c\u308b\u306e\u3067\u4e2d\u8eab\u3092\u4ee5\u4e0b\u306e\u3088\u3046\u306b\u3057\u307e\u3059\u3002<\/p>\n<\/div>\n<\/div>\n<p><strong>resources\/views\/application_form\/create.blade.php<\/strong><\/p>\n<div>\n<pre><strong>&lt;!DOCTYPE html&gt;<\/strong>\r\n<strong>&lt;html lang=\"ja\"&gt;<\/strong>\r\n<strong>&lt;head&gt;<\/strong>\r\n<strong>    &lt;meta charset=\"UTF-8\"&gt;<\/strong>\r\n<strong>    &lt;meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\"&gt;<\/strong>\r\n<strong>    &lt;title&gt;\u30a8\u30f3\u30c8\u30ea\u30fc\u30b7\u30fc\u30c8&lt;\/title&gt;<\/strong>\r\n<strong>&lt;\/head&gt;<\/strong>\r\n<strong>&lt;body id=\"app\" class=\"bg-gray-100 p-8\"&gt;<\/strong>\r\n<strong>    &lt;div class=\"max-w-md mx-auto\"&gt;<\/strong>\r\n<strong>        &lt;h1 class=\"text-3xl font-bold mb-8\"&gt;\u30a8\u30f3\u30c8\u30ea\u30fc\u30b7\u30fc\u30c8&lt;\/h1&gt;<\/strong>\r\n<strong>        &lt;div class=\"space-y-6\"&gt;<\/strong>\r\n<strong>            &lt;div&gt;<\/strong>\r\n<strong>                &lt;label class=\"block text-sm font-medium text-gray-700\"&gt;\u304a\u540d\u524d:&lt;\/label&gt;<\/strong>\r\n<strong>                &lt;input<\/strong>\r\n<strong>                    id=\"name\"<\/strong>\r\n<strong>                    type=\"text\"<\/strong>\r\n<strong>                    class=\"mt-1 block w-full px-4 py-2 border border-gray-300 rounded-md shadow-sm focus:outline-none focus:ring-indigo-500 focus:border-indigo-500\"<\/strong>\r\n<strong>                    v-model=\"form.name\"<\/strong>\r\n<strong>                    @keydown=\"onKeydown\"<\/strong>\r\n<strong>                    @keyup=\"onKeyup\"<\/strong>\r\n<strong>                    @focus=\"onFocus\"&gt;<\/strong>\r\n<strong>            &lt;\/div&gt;<\/strong>\r\n<strong>            &lt;div&gt;<\/strong>\r\n<strong>                &lt;label class=\"block text-sm font-medium text-gray-700\"&gt;\u30e1\u30fc\u30eb\u30a2\u30c9\u30ec\u30b9:&lt;\/label&gt;<\/strong>\r\n<strong>                &lt;input<\/strong>\r\n<strong>                    id=\"email\"<\/strong>\r\n<strong>                    type=\"text\"<\/strong>\r\n<strong>                    class=\"mt-1 block w-full px-4 py-2 border border-gray-300 rounded-md shadow-sm focus:outline-none focus:ring-indigo-500 focus:border-indigo-500\"<\/strong>\r\n<strong>                    v-model=\"form.email\"<\/strong>\r\n<strong>                    @keydown=\"onKeydown\"<\/strong>\r\n<strong>                    @keyup=\"onKeyup\"<\/strong>\r\n<strong>                    @focus=\"onFocus\"&gt;<\/strong>\r\n<strong>            &lt;\/div&gt;<\/strong>\r\n<strong>            &lt;div&gt;<\/strong>\r\n<strong>                &lt;label class=\"block text-sm font-medium text-gray-700\"&gt;\u5fd7\u671b\u52d5\u6a5f:&lt;\/label&gt;<\/strong>\r\n<strong>                &lt;textarea<\/strong>\r\n<strong>                    id=\"motivation\"<\/strong>\r\n<strong>                    class=\"mt-1 block w-full px-4 py-2 border border-gray-300 rounded-md shadow-sm focus:outline-none focus:ring-indigo-500 focus:border-indigo-500\"<\/strong>\r\n<strong>                    rows=\"5\"<\/strong>\r\n<strong>                    v-model=\"form.motivation\"<\/strong>\r\n<strong>                    @keydown=\"onKeydown\"<\/strong>\r\n<strong>                    @keyup=\"onKeyup\"<\/strong>\r\n<strong>                    @focus=\"onFocus\"&gt;&lt;\/textarea&gt;<\/strong>\r\n<strong>            &lt;\/div&gt;<\/strong>\r\n<strong>            &lt;div&gt;<\/strong>\r\n<strong>                &lt;label class=\"block text-sm font-medium text-gray-700\"&gt;\u8077\u52d9\u7d4c\u6b74:&lt;\/label&gt;<\/strong>\r\n<strong>                &lt;textarea<\/strong>\r\n<strong>                    id=\"career\"<\/strong>\r\n<strong>                    class=\"mt-1 block w-full px-4 py-2 border border-gray-300 rounded-md shadow-sm focus:outline-none focus:ring-indigo-500 focus:border-indigo-500\"<\/strong>\r\n<strong>                    rows=\"5\"<\/strong>\r\n<strong>                    v-model=\"form.career\"<\/strong>\r\n<strong>                    @keydown=\"onKeydown\"<\/strong>\r\n<strong>                    @keyup=\"onKeyup\"<\/strong>\r\n<strong>                    @focus=\"onFocus\"&gt;&lt;\/textarea&gt;<\/strong>\r\n<strong>            &lt;\/div&gt;<\/strong>\r\n<strong>            &lt;button<\/strong>\r\n<strong>                type=\"button\"<\/strong>\r\n<strong>                class=\"w-full flex justify-center py-3 px-4 border border-transparent text-sm font-medium rounded-md text-white bg-indigo-600 hover:bg-indigo-700 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-indigo-500\"<\/strong>\r\n<strong>                @click=\"onSubmit\"&gt;<\/strong>\r\n<strong>                \u9001\u4fe1<\/strong>\r\n<strong>            &lt;\/button&gt;<\/strong>\r\n<strong>        &lt;\/div&gt;<\/strong>\r\n<strong>    &lt;\/div&gt;<\/strong>\r\n<strong>    &lt;script src=\"https:\/\/cdn.tailwindcss.com\/3.3.5\"&gt;&lt;\/script&gt;<\/strong>\r\n<strong>    &lt;script src=\"https:\/\/unpkg.com\/vue@3.3.11\/dist\/vue.global.prod.js\"&gt;&lt;\/script&gt;<\/strong>\r\n<strong>    &lt;script src=\"https:\/\/cdn.jsdelivr.net\/npm\/axios\/dist\/axios.min.js\"&gt;&lt;\/script&gt;<\/strong>\r\n<strong>    &lt;script src=\"https:\/\/cdn.jsdelivr.net\/npm\/lodash@4.17.21\/lodash.min.js\"&gt;&lt;\/script&gt;<\/strong>\r\n<strong>    &lt;script&gt;<\/strong>\r\n\r\n<strong>        Vue.createApp({<\/strong>\r\n<strong>            data() {<\/strong>\r\n\r\n<strong>                return {<\/strong>\r\n<strong>                    form: {<\/strong>\r\n<strong>                        name: '',<\/strong>\r\n<strong>                        email: '',<\/strong>\r\n<strong>                        motivation: '',<\/strong>\r\n<strong>                        career: ''<\/strong>\r\n<strong>                    },<\/strong>\r\n<strong>                    typingData: {<\/strong>\r\n<strong>                        durations: [],<\/strong>\r\n<strong>                        backspaceCount: 0,<\/strong>\r\n<strong>                        inputStartTimes: {},<\/strong>\r\n<strong>                        inputEndTimes: {},<\/strong>\r\n<strong>                        startTime: 0,<\/strong>\r\n<strong>                    },<\/strong>\r\n<strong>                    lastKeyUpTime: 0,<\/strong>\r\n<strong>                };<\/strong>\r\n\r\n<strong>            },<\/strong>\r\n<strong>            methods: {<\/strong>\r\n<strong>                onKeydown(e) {<\/strong>\r\n\r\n<strong>                    if(this.lastKeyUpTime &gt; 0) {<\/strong>\r\n\r\n<strong>                        const duration = Date.now() - this.lastKeyUpTime;<\/strong>\r\n<strong>                        this.typingData.durations.push(duration); \/\/ \u30ad\u30fc\u30dc\u30fc\u30c9\u306e\u30bf\u30a4\u30d4\u30f3\u30b0\u901f\u5ea6<\/strong>\r\n\r\n<strong>                    }<\/strong>\r\n\r\n<strong>                    if (e.key === 'Backspace') { \/\/ \u30d0\u30c3\u30af\u30b9\u30da\u30fc\u30b9<\/strong>\r\n\r\n<strong>                        this.typingData.backspaceCount++;<\/strong>\r\n\r\n<strong>                    }<\/strong>\r\n\r\n<strong>                    const inputId = e.target.id;<\/strong>\r\n\r\n<strong>                    if (typeof this.typingData.inputStartTimes[inputId] === 'undefined') {<\/strong>\r\n\r\n<strong>                        this.typingData.inputStartTimes[inputId] = Date.now();<\/strong>\r\n\r\n<strong>                    }<\/strong>\r\n\r\n<strong>                },<\/strong>\r\n<strong>                onKeyup(e) {<\/strong>\r\n\r\n<strong>                    if(e.key === 'Tab') { \/\/ \u30bf\u30d6\u306e\u3068\u304d\u306f\u7121\u8996<\/strong>\r\n\r\n<strong>                        return;<\/strong>\r\n\r\n<strong>                    }<\/strong>\r\n\r\n<strong>                    this.lastKeyUpTime = Date.now();<\/strong>\r\n\r\n<strong>                    const inputId = e.target.id;<\/strong>\r\n<strong>                    this.typingData.inputEndTimes[inputId] = Date.now();<\/strong>\r\n\r\n<strong>                },<\/strong>\r\n<strong>                onFocus() {<\/strong>\r\n\r\n<strong>                    \/\/ \u30d5\u30a9\u30fc\u30ab\u30b9\u3057\u305f\u3068\u304d\u306f\u3001\u76f4\u524d\u306e\u30ad\u30fc\u5165\u529b\u304b\u3089\u306e\u7d4c\u904e\u6642\u9593\u3092\u30ea\u30bb\u30c3\u30c8<\/strong>\r\n<strong>                    this.lastKeyUpTime = 0;<\/strong>\r\n\r\n<strong>                },<\/strong>\r\n<strong>                onSubmit() {<\/strong>\r\n\r\n<strong>                    if(confirm('\u9001\u4fe1\u3057\u307e\u3059\u304b\uff1f') === false) {<\/strong>\r\n\r\n<strong>                        return;<\/strong>\r\n\r\n<strong>                    }<\/strong>\r\n\r\n<strong>                    \/\/ \u30bf\u30a4\u30d4\u30f3\u30b0\u901f\u5ea6<\/strong>\r\n<strong>                    const averageKeystrokeDuration = _.mean(this.typingData.durations);<\/strong>\r\n\r\n<strong>                    \/\/ \u30d0\u30c3\u30af\u30b9\u30da\u30fc\u30b9\u6bd4\u7387<\/strong>\r\n<strong>                    const inputTextCount =<\/strong>\r\n<strong>                        this.form.name.length +<\/strong>\r\n<strong>                        this.form.email.length +<\/strong>\r\n<strong>                        this.form.motivation.length +<\/strong>\r\n<strong>                        this.form.career.length;<\/strong>\r\n<strong>                    const backspaceRatio = this.typingData.backspaceCount \/ inputTextCount || 0;<\/strong>\r\n\r\n<strong>                    \/\/ \u5404\u9805\u76ee\u306e\u5165\u529b\u6642\u9593<\/strong>\r\n<strong>                    let entryTimes = {};<\/strong>\r\n\r\n<strong>                    for (const key in this.typingData.inputStartTimes) {<\/strong>\r\n\r\n<strong>                        const startTime = this.typingData.inputStartTimes[key];<\/strong>\r\n<strong>                        const endTime = this.typingData.inputEndTimes[key];<\/strong>\r\n<strong>                        entryTimes[key] = endTime - startTime;<\/strong>\r\n\r\n<strong>                    }<\/strong>\r\n\r\n<strong>                    \/\/ \u30da\u30fc\u30b8\u304c\u8868\u793a\u3055\u308c\u3066\u304b\u3089\u9001\u4fe1\u3059\u308b\u307e\u3067\u306e\u7d4c\u904e\u6642\u9593<\/strong>\r\n<strong>                    const totalTime = Date.now() - this.typingData.startTime;<\/strong>\r\n\r\n<strong>                    const url = '\/application_form';<\/strong>\r\n<strong>                    const params = {<\/strong>\r\n<strong>                        form: this.form,<\/strong>\r\n<strong>                        typing_data: {<\/strong>\r\n<strong>                            average_keystroke_duration: averageKeystrokeDuration,<\/strong>\r\n<strong>                            backspace_ratio: backspaceRatio,<\/strong>\r\n<strong>                            entry_times: entryTimes,<\/strong>\r\n<strong>                            total_time: totalTime,<\/strong>\r\n<strong>                        }<\/strong>\r\n<strong>                    };<\/strong>\r\n\r\n<strong>                    axios.post(url, params)<\/strong>\r\n<strong>                        .then((response) =&gt; {<\/strong>\r\n\r\n<strong>                            if(response.data.status === 'success') {<\/strong>\r\n\r\n<strong>                                alert(response.data.chatgpt_response);<\/strong>\r\n\r\n<strong>                            }<\/strong>\r\n\r\n<strong>                        });<\/strong>\r\n\r\n<strong>                }<\/strong>\r\n<strong>            },<\/strong>\r\n<strong>            mounted() {<\/strong>\r\n\r\n<strong>                this.typingData.startTime = Date.now();<\/strong>\r\n\r\n<strong>            },<\/strong>\r\n<strong>        })<\/strong>\r\n<strong>        .mount('#app');<\/strong>\r\n\r\n<strong>    &lt;\/script&gt;<\/strong>\r\n<strong>&lt;\/body&gt;<\/strong>\r\n<strong>&lt;\/html&gt;<\/strong><\/pre>\n<\/div>\n<div>\n<p>\u3059\u3053\u3057\u30b3\u30fc\u30c9\u304c\u9577\u3044\u3067\u3059\u304c\u3001\u3084\u3063\u3066\u3044\u308b\u3053\u3068\u306f\u5192\u982d\u3067\u3082\u7d39\u4ecb\u3057\u305f\u4ee5\u4e0b\u306e\u9805\u76ee\u3068\u300c<strong>\u30da\u30fc\u30b8\u304c\u8868\u793a\u3055\u308c\u3066\u304b\u3089\u9001\u4fe1\u3059\u308b\u307e\u3067\u306e\u6642\u9593<\/strong>\u300d\u3092\u9001\u4fe1\u3057\u3066\u3044\u308b\u3060\u3051\u3067\u3059<\/p>\n<ul>\n<li>\u30ad\u30fc\u30dc\u30fc\u30c9\u306e\u30bf\u30a4\u30d4\u30f3\u30b0\u901f\u5ea6<\/li>\n<li>\u30d0\u30c3\u30af\u30b9\u30da\u30fc\u30b9\u3084 Delete \u30ad\u30fc\u306e\u4f7f\u7528\u983b\u5ea6\uff08\u9593\u9055\u3044\u3092\u4fee\u6b63\u3059\u308b\u56de\u6570\uff09<\/li>\n<li>\u5404\u7a2e\u30dc\u30c3\u30af\u30b9\u306b\u5165\u529b\u3057\u305f\u6642\u9593<\/li>\n<\/ul>\n<p>\u307e\u305f\u3001\u30ad\u30fc\u30dc\u30fc\u30c9\u306e\u30bf\u30a4\u30d4\u30f3\u30b0\u901f\u5ea6\u306f\u4ee5\u4e0b\u306e\u6d41\u308c\u3067\u53d6\u5f97\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n<ul>\n<li>\u6700\u5f8c\u306b\u300c\u30ad\u30fc\u30a2\u30c3\u30d7\u300d\u3055\u308c\u305f\u6642\u9593\u3092\u3068\u3063\u3066\u304a\u304f<\/li>\n<li>\u30ad\u30fc\u30c0\u30a6\u30f3\u3055\u308c\u305f\u6642\u9593\u3068\u306e\u5dee\u3092\u8a08\u7b97\uff08\u3053\u308c\u3092\u30bf\u30a4\u30d7\u901f\u5ea6\u3068\u3059\u308b\uff09<\/li>\n<li>\u305f\u3060\u3057\u3001Tab\u3067\u79fb\u52d5\u3055\u308c\u308b\u3068\u3046\u307e\u304f\u3044\u304b\u306a\u3044\u306e\u3067\u30bf\u30d6\u306f\u7121\u52b9\u306b\u3059\u308b<\/li>\n<\/ul>\n<\/div>\n<h1>\u30d3\u30e5\u30fc\uff08\u30d7\u30ed\u30f3\u30d7\u30c8\u7528\uff09\u3092\u3064\u304f\u308b<\/h1>\n<p>\u3067\u306f\u3001\u3082\u3046\uff11\u3064\u30b3\u30f3\u30c8\u30ed\u30fc\u30e9\u30fc\u306e\u4e2d\u3067\u4f7f\u3063\u3066\u3044\u308b\u300c<strong>\u30d7\u30ed\u30f3\u30d7\u30c8\u7528<\/strong>\u300d\u306e\u30d3\u30e5\u30fc\u3092\u3064\u304f\u308a\u307e\u3059\u3002<\/p>\n<p>\u4ee5\u4e0b\u306e\u30b3\u30de\u30f3\u30c9\u3092\u5b9f\u884c\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n<div>\n<pre><strong>php artisan make:view application_form.prompt<\/strong><\/pre>\n<p>\u3059\u308b\u3068\u3001\u540c\u3058\u304f<code>resources\/views\/application_form<\/code>\u306b\u30d5\u30a1\u30a4\u30eb\u304c\u4f5c\u6210\u3055\u308c\u308b\u306e\u3067\u4e2d\u8eab\u3092\u4ee5\u4e0b\u306e\u3088\u3046\u306b\u3057\u307e\u3059\u3002<\/p>\n<p><strong>resources\/views\/application_form\/prompt.blade.php<\/strong><\/p>\n<div>\n<pre><strong>\u3042\u306a\u305f\u306f\u3001\u884c\u52d5\u7684\u751f\u4f53\u8a8d\u8a3c\uff08Behavioral Biometrics\uff09\u306e\u512a\u79c0\u306a\u30b9\u30da\u30b7\u30e3\u30ea\u30b9\u30c8\u3067\u3059\u3002<\/strong>\r\n<strong>\u4ee5\u4e0b\u306f\u5165\u793e\u5e0c\u671b\u8005\u304c\u5fdc\u52df\u30d5\u30a9\u30fc\u30e0\u5165\u529b\u3057\u305f\u969b\u306e\u5404\u7a2e\u30bf\u30a4\u30d4\u30f3\u30b0\u30c7\u30fc\u30bf\u3067\u3059\u3002<\/strong>\r\n\r\n<strong>\u3053\u308c\u3089\u3092\u4f7f\u3063\u3066\u5165\u793e\u5e0c\u671b\u3092\u3057\u3066\u3044\u308b\u4eba\u306e\u6027\u683c\u3092\u5206\u6790\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/strong>\r\n\r\n<strong># \u30ad\u30fc\u30dc\u30fc\u30c9\u306e\u30bf\u30a4\u30d4\u30f3\u30b0\u901f\u5ea6\uff08\u5e73\u5747\uff09<\/strong>\r\n<strong>{{ $typing_data['average_keystroke_duration'] }}\u30df\u30ea\u79d2<\/strong>\r\n\r\n<strong># \u5165\u529b\u3055\u308c\u305f\u30c6\u30ad\u30b9\u30c8\u6587\u5b57\u6570\u306b\u5bfe\u3059\u308b\u30d0\u30c3\u30af\u30b9\u30da\u30fc\u30b9\u306e\u4f7f\u7528\u56de\u6570\uff08\u6bd4\u7387\uff09<\/strong>\r\n<strong>{{ $typing_data['backspace_ratio'] }}\u56de<\/strong>\r\n\r\n<strong># \u5404\u9805\u76ee\u306e\u5165\u529b\u6642\u9593\uff08\u5e73\u5747\uff09<\/strong>\r\n<strong>@foreach($typing_data['entry_times'] as $key =&gt; $entry_time)<\/strong>\r\n<strong>{{ $key }}: {{ $entry_time }}\u30df\u30ea\u79d2<\/strong>\r\n<strong>@endforeach<\/strong>\r\n\r\n<strong># \u30da\u30fc\u30b8\u304c\u8868\u793a\u3055\u308c\u3066\u304b\u3089\u9001\u4fe1\u3059\u308b\u307e\u3067\u306e\u7d4c\u904e\u6642\u9593<\/strong>\r\n<strong>{{ $typing_data['total_time'] }}\u30df\u30ea\u79d2<\/strong><\/pre>\n<\/div>\n<\/div>\n<h1>\u30eb\u30fc\u30c8\u3092\u3064\u304f\u308b<\/h1>\n<p>\u3067\u306f\u3001\u6700\u5f8c\u306b\u30eb\u30fc\u30c8\u3067\u3059\u3002<br \/>\n\u4ee5\u4e0b\u306e\u3088\u3046\u306b\u30b3\u30fc\u30c9\u3092\u8ffd\u52a0\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n<p><strong>routes\/web.php<\/strong><\/p>\n<div>\n<pre><strong>use App\\Http\\Controllers\\ApplicationFormController;<\/strong>\r\n\r\n<strong>\/\/ \u7701\u7565<\/strong>\r\n\r\n<strong>Route::prefix('application_form')-&gt;controller(ApplicationFormController::class)-&gt;group(function(){<\/strong>\r\n\r\n<strong>    Route::get('create', 'create')-&gt;name('application_form.create');<\/strong>\r\n<strong>    Route::post('\/', 'store')-&gt;name('application_form.store');<\/strong>\r\n\r\n<strong>});<\/strong><\/pre>\n<p>\u3053\u308c\u3067\u4f5c\u696d\u306f\u5b8c\u4e86\u3067\u3059\u3002<br \/>\n\u304a\u75b2\u308c\u69d8\u3067\u3057\u305f\u3002\ud83d\ude04\u2728<\/p>\n<\/div>\n<h1>\u30c6\u30b9\u30c8\u3057\u3066\u307f\u308b<\/h1>\n<p>\u3067\u306f\u5b9f\u969b\u306b\u30c6\u30b9\u30c8\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002<\/p>\n<p>\u307e\u305a\u3001\u30d6\u30e9\u30a6\u30b6\u3067\u300c<strong>https:\/\/******\/application_form\/create<\/strong>\u300d\u3078\u30a2\u30af\u30bb\u30b9\u3057\u307e\u3059\u3002<\/p>\n<p>\u3059\u308b\u3068\u3001\u30a8\u30f3\u30c8\u30ea\u30fc\u30b7\u30fc\u30c8\u306e\u30d5\u30a9\u30fc\u30e0\u304c\u8868\u793a\u3055\u308c\u308b\u306e\u3067\u3001\uff08\u308f\u3056\u3068\u9593\u9055\u3048\u3066\u4fee\u6b63\u3057\u305f\u308a\u3057\u3066\u3001\u30ea\u30a2\u30eb\u306a\u30ab\u30f3\u30b8\u3067\uff09\u4ee5\u4e0b\u306e\u3088\u3046\u306b\u5165\u529b\uff06\u9001\u4fe1\u3057\u3066\u307f\u307e\u3059\u3002<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-full wp-image-12241\" style=\"border: 3px solid #000;\" src=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/12\/laravel_application_form_with_chatgpt_2.png\" alt=\"\" width=\"502\" height=\"710\" srcset=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/12\/laravel_application_form_with_chatgpt_2.png 502w, https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/12\/laravel_application_form_with_chatgpt_2-212x300.png 212w\" sizes=\"auto, (max-width: 502px) 100vw, 502px\" \/><\/p>\n<p>\u3059\u308b\u3068\u3001\u3069\u3046\u306a\u308b\u3067\u3057\u3087\u3046\u304b\u30fb\u30fb\u30fb\u30fb\u30fb\u30fb<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-full wp-image-12242\" style=\"border: 3px solid #000;\" src=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/12\/laravel_application_form_with_chatgpt_1.png\" alt=\"\" width=\"492\" height=\"352\" srcset=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/12\/laravel_application_form_with_chatgpt_1.png 492w, https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2023\/12\/laravel_application_form_with_chatgpt_1-300x215.png 300w\" sizes=\"auto, (max-width: 492px) 100vw, 492px\" \/><\/p>\n<p>\u306f\u3044\u2757<br \/>\n<code>ChatGPT<\/code>\uff08<code>Open AI<\/code>\uff09\u304b\u3089\u53d6\u5f97\u3055\u308c\u305f\u5185\u5bb9\u304c\u8868\u793a\u3055\u308c\u307e\u3057\u305f\u3002<\/p>\n<p>\u3067\u306f\u3001\u305d\u306e\u5185\u5bb9\u3092\u898b\u3066\u307f\u307e\u3057\u3087\u3046\u3002<\/p>\n<p><strong>\uff08ChatGPT \u306b\u3088\u308b\u6027\u683c\u5224\u65ad\uff09<\/strong><\/p>\n<p>\u30bf\u30a4\u30d4\u30f3\u30b0\u901f\u5ea6\u306f\u5e73\u5747\u7684\u306a\u5024\u3067\u3042\u308a\u3001\u65e9\u3059\u304e\u305a\u9045\u3059\u304e\u305a\u3001\u8a08\u753b\u7684\u3067\u5b89\u5b9a\u3057\u305f\u4f5c\u696d\u304c\u3067\u304d\u308b\u6027\u683c\u3092\u793a\u3057\u3066\u3044\u308b\u53ef\u80fd\u6027\u304c\u3042\u308a\u307e\u3059\u3002\u307e\u305f\u3001\u30d0\u30c3\u30af\u30b9\u30da\u30fc\u30b9\u306e\u4f7f\u7528\u56de\u6570\u304c\u5c11\u306a\u3044\u3053\u3068\u304b\u3089\u3001\u81ea\u4fe1\u304c\u3042\u308b\u304b\u3001\u307e\u305f\u306f\u4e8b\u524d\u306b\u8003\u3048\u3092\u307e\u3068\u3081\u3066\u304b\u3089\u30bf\u30a4\u30d4\u30f3\u30b0\u3059\u308b\u3088\u3046\u306a\u884c\u52d5\u7279\u6027\u304c\u898b\u3089\u308c\u307e\u3059\u3002<\/p>\n<p>\u5404\u9805\u76ee\u306e\u5165\u529b\u6642\u9593\u3092\u898b\u308b\u3068\u3001\u540d\u524d\u3068\u30e1\u30fc\u30eb\u30a2\u30c9\u30ec\u30b9\u306f\u901f\u3081\u3067\u3001\u7279\u306b\u8077\u6b74\u306e\u5165\u529b\u6642\u9593\u304c\u9577\u3044\u4e8b\u304b\u3089\u3001\u7d30\u90e8\u306b\u914d\u616e\u3059\u308b\u5074\u9762\u3084\u5fb9\u5e95\u7684\u306b\u60c5\u5831\u3092\u30c1\u30a7\u30c3\u30af\u3059\u308b\u614e\u91cd\u3055\u3092\u611f\u3058\u307e\u3059\u3002<\/p>\n<p>\u5168\u4f53\u306e\u9001\u4fe1\u307e\u3067\u306e\u6642\u9593\u306f\u7d0446\u79d2\u3068\u3001\u4e00\u822c\u7684\u306a\u30bf\u30a4\u30e0\u30d5\u30ec\u30fc\u30e0\u5185\u306b\u53ce\u307e\u3063\u3066\u304a\u308a\u3001\u52b9\u7387\u7684\u3067\u3042\u308b\u3068\u8a00\u3048\u307e\u3059\u3002\u3053\u308c\u306f\u6ce8\u610f\u6df1\u304f\u3001\u5177\u4f53\u7684\u304b\u3064\u76f4\u63a5\u7684\u306a\u4f5c\u696d\u3092\u884c\u3046\u80fd\u529b\u3092\u793a\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>\u3053\u308c\u3089\u306e\u30c7\u30fc\u30bf\u304b\u3089\u3001\u5165\u793e\u5e0c\u671b\u8005\u306f\u8a08\u753b\u7684\u3067\u3042\u308b\u3068\u540c\u6642\u306b\u6ce8\u610f\u6df1\u304f\u3001\u307e\u305f\u81ea\u8eab\u306e\u4f5c\u696d\u306b\u81ea\u4fe1\u3068\u8cac\u4efb\u611f\u3092\u6301\u3063\u3066\u53d6\u308a\u7d44\u3080\u3053\u3068\u304c\u3067\u304d\u308b\u3068\u8003\u3048\u3089\u308c\u307e\u3059\u3002\u3053\u306e\u3053\u3068\u304b\u3089\u3001\u3053\u306e\u4eba\u7269\u306f\u7d44\u7e54\u306b\u5bfe\u3057\u3066\u610f\u7fa9\u6df1\u304b\u3064\u751f\u7523\u7684\u306a\u8ca2\u732e\u3092\u3059\u308b\u3053\u3068\u304c\u671f\u5f85\u3067\u304d\u307e\u3059\u3002<\/p>\n<p>\u306f\u3044\u2757<\/p>\n<p>\uff08\u5185\u5bb9\u304c\u3069\u3046\u304b\u306f\u3055\u3066\u304a\u304d\uff09\u3046\u307e\u304f\u6027\u683c\u5224\u65ad\u304c\u8868\u793a\u3055\u308c\u307e\u3057\u305f\u3002<\/p>\n<p>\u3059\u3079\u3066\u6210\u529f\u3067\u3059\ud83d\ude04\u2728<\/p>\n<h1>\u4f01\u696d\u69d8\u3078\u306e\u3054\u63d0\u6848<\/h1>\n<p>\u3082\u3061\u308d\u3093\u4eca\u56de\u306e\u5224\u5225\u304c\u7d76\u5bfe\u7684\u306b\u6b63\u3057\u3044\u304b\u3068\u8a00\u3048\u3070\u305d\u3046\u3067\u306f\u3042\u308a\u307e\u305b\u3093\u304c\u3001\uff11\u3064\u306e\u5224\u65ad\u6750\u6599\u306b\u306f\u306a\u308b\u306e\u3067\u306f\u306a\u3044\u3067\u3057\u3087\u3046\u304b\u3002<\/p>\n<p>\u307e\u305f\u3001\u4eca\u56de\u306f\u30c6\u30b9\u30c8\u306a\u306e\u3067\u30c7\u30fc\u30bf\u306f\u591a\u304f\u3042\u308a\u307e\u305b\u3093\u304c\u3001\u5192\u982d\u3067\u3082\u8a00\u53ca\u3057\u305f\u300c<strong>\u30de\u30a6\u30b9\u306e\u79fb\u52d5\u901f\u5ea6<\/strong>\u300d\u306a\u3069\u305d\u306e\u4ed6\u306e\u30c7\u30fc\u30bf\u3082\u7d44\u307f\u5408\u308f\u305b\u308b\u3068\u3088\u308a\u7cbe\u5ea6\u304c\u9ad8\u3044\u6027\u683c\u5224\u65ad\u304c\u3067\u304d\u308b\u3068\u8003\u3048\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>\u3082\u3057\u305d\u3046\u3044\u3063\u305f\u30b7\u30b9\u30c6\u30e0\u3092\u3054\u7528\u610f\u3055\u308c\u305f\u3044\u65b9\u306f\u305c\u3072\u304a\u554f\u3044\u5408\u308f\u305b\u304b\u3089\u3054\u76f8\u8ac7\u304f\u3060\u3055\u3044\u3002<\/p>\n<p>\u304a\u5f85\u3061\u3057\u3066\u304a\u308a\u307e\u3059\u3002\ud83d\ude04\u2728<\/p>\n<h1>\u304a\u308f\u308a\u306b<\/h1>\n<p>\u3068\u3044\u3046\u3053\u3068\u3067\u4eca\u56de\u306f\u300c<strong>ChatGPT<\/strong>\u300d\u3067\u63a1\u7528\u306b\u95a2\u9023\u3059\u308b\u6027\u683c\u5224\u65ad\u3092\u3057\u3066\u307f\u307e\u3057\u305f\u3002<\/p>\n<p>\u306a\u304a\u3001\u306f\u3058\u3081\u306f\u300c<strong>gpt-3.5-turbo<\/strong>\u300d\u3067\u3084\u3063\u3066\u307f\u305f\u3068\u3053\u308d\u3001\u300e\u7533\u3057\u8a33\u306a\u3044\u3067\u3059\u3051\u3069\u3067\u304d\u307e\u305b\u3093\u300f\u300d\u3068\u8a00\u308f\u308c\u3046\u307e\u304f\u3044\u304b\u305a\u3001\u6700\u65b0\u7248\u306e\u300c<code>gpt-4-1106-preview<\/code>\uff08<code>gpt-4<\/code>\u3088\u308a\u9ad8\u6027\u80fd\u306a\u306e\u306b\u5b89\u3044\uff09\u300d\u3092\u4f7f\u3063\u3066\u307f\u305f\u3089\u3001<code>cURL error 28: Operation timed out<\/code>\u3068\u306a\u308a\u3046\u307e\u304f\u3044\u304d\u307e\u305b\u3093\u3067\u3057\u305f\u3002<\/p>\n<p>\u305d\u3053\u3067\u3001\u300c<strong>gpt-4<\/strong>\u300d\u30e2\u30c7\u30eb\u3092\u4f7f\u3046\u3068\u3046\u307e\u304f\u3044\u304d\u307e\u3057\u305f\u306e\u3067\u6700\u7d42\u7684\u306b\u306f\u3053\u308c\u306b\u3057\u307e\u3057\u305f\u3002\uff08\u65b0\u3057\u3044\u3084\u3064\u306f\u30a2\u30af\u30bb\u30b9\u304c\u591a\u3059\u304e\u308b\u3093\u3067\u3057\u3087\u3046\u304b\u2026\ud83e\udd14\uff09<\/p>\n<p>\u306a\u3093\u306b\u305b\u3088\u3001<code>ChatGPT<\/code>\u306f\u3053\u3046\u3044\u3046\u4f7f\u3044\u65b9\u3092\u3059\u308b\u3068\u5b8c\u74a7\u3067\u306f\u306a\u3044\u306b\u305b\u3088\u3001\u3061\u3087\u3063\u3068\u3057\u305f\u5c02\u9580\u5bb6\u306e\u529b\u3092\u501f\u308a\u308b\u3053\u3068\u304c\u3067\u304d\u308b\u3088\u3046\u306b\u306a\u308b\u306e\u3067\u4fbf\u5229\u3067\u3059\u306d\u3002<\/p>\n<p>\u305c\u3072\u7686\u3055\u3093\u3082\u3084\u3063\u3066\u307f\u3066\u304f\u3060\u3055\u3044\u306d\u3002<\/p>\n<p>\u3067\u306f\u3067\u306f\u301c\u2757<\/p>\n<p style=\"text-align: center;\"><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-full wp-image-9470 aligncenter\" src=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2021\/08\/no_13.png\" alt=\"\" width=\"294\" height=\"320\" srcset=\"https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2021\/08\/no_13.png 294w, https:\/\/blog.capilano-fw.com\/wp-content\/uploads\/2021\/08\/no_13-276x300.png 276w\" sizes=\"auto, (max-width: 294px) 100vw, 294px\" \/>\u300c\u30a8\u30ac\u3061\u3083\u3093\u306d\u308b\u3067\u898b\u305f<br \/>\n\u6a2a\u6d5c\u3042\u3093\u304b\u3051\u30e9\u30fc\u30e1\u30f3\uff08\u51b7\u51cd\u98df\u54c1\uff09\u3001<br \/>\n\u30ac\u30c1\u3067\u3046\u307e\u304b\u3063\u305f\u3067\u3059\u300d<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u3055\u3066\u3055\u3066\u3001\u6628\u4eca\u3088\u304f\u8a00\u308f\u308c\u308b\u306e\u304c\u300c\u4eba\u624b\u4e0d\u8db3\u300d\u3067\u3059\u3088\u306d\u3002 \u6211\u3005IT\u696d\u754c\u3082\u305d\u306e\u4f8b\u306b\u3082\u308c\u305a\u6162\u6027\u7684\u306a\u4eba\u624b\u4e0d\u8db3\u3068\u306a\u3063\u3066\u3044\u308b\u8077\u5834\u3082\u591a\u304b\u3063\u305f\u308a\u3059\u308b\u3093\u3058\u3083\u306a\u3044\u3067\u3057\u3087\u3046\u304b\u3002 \u305f\u3060\u3001 &hellip; <\/p>\n<p class=\"link-more\"><a href=\"https:\/\/blog.capilano-fw.com\/?p=12237\" class=\"more-link\"><span class=\"screen-reader-text\">&#8220;\u300cChatGPT + \u30d5\u30a9\u30fc\u30e0\u64cd\u4f5c\u30c7\u30fc\u30bf\u300d\u3067\u6027\u683c\u5224\u5225\u3057\u3001\u30ea\u30af\u30eb\u30fc\u30c8\u306b\u5f79\u7acb\u3066\u308b&#8221; \u306e<\/span>\u7d9a\u304d\u3092\u8aad\u3080<\/a><\/p>\n","protected":false},"author":1,"featured_media":12249,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[253,3],"tags":[],"class_list":["post-12237","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-chatgpt","category-laravel"],"_links":{"self":[{"href":"https:\/\/blog.capilano-fw.com\/index.php?rest_route=\/wp\/v2\/posts\/12237","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/blog.capilano-fw.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/blog.capilano-fw.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/blog.capilano-fw.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/blog.capilano-fw.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=12237"}],"version-history":[{"count":8,"href":"https:\/\/blog.capilano-fw.com\/index.php?rest_route=\/wp\/v2\/posts\/12237\/revisions"}],"predecessor-version":[{"id":12248,"href":"https:\/\/blog.capilano-fw.com\/index.php?rest_route=\/wp\/v2\/posts\/12237\/revisions\/12248"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/blog.capilano-fw.com\/index.php?rest_route=\/wp\/v2\/media\/12249"}],"wp:attachment":[{"href":"https:\/\/blog.capilano-fw.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=12237"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/blog.capilano-fw.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=12237"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/blog.capilano-fw.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=12237"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}