2019/12/18

[ASP.NET MVC] Visual Studio 2019 v16.4.x 右鍵加入找不到 Area 的問題

markdown ### 環境 - Visual Studio 2019 v16.4.1 - ASP.NET MVC 5 ### 問題 更新 Visual Studio 版本後,找不到加入 MVC 的 Area 區域 ### 解決方法 功能被整合至 New Scaffolded Item,步驟如下: 在專案上按右鍵 --> Add 加入,選擇 New Scaffolded Item 選擇 MVC 下的 Area,即可找到 MVC 5 Area 突然找不到功能,小驚慌了一下 XD

2019/11/18

[ASP.NET MVC] 如何在 MVC 專案下使用 Unity.Mvc IoC 依賴注入

markdown ### 前言 在 ASP.NET Core 的環境, 預設早已支援 Dependency Injection (依賴注入) 的設計模式, 但在 ASP.NET MVC 5 以前的專案沒有這樣的功能, 本篇簡單介紹如何使用 Unity.Mvc 套件來達成依賴注入。 ### 環境 - Visual Studio 2019 16.3.9 - ASP.NET MVC 5 - .NET Framework 4.7.2 - NuGet 套件: [Unity.Mvc](https://github.com/unitycontainer/aspnet-mvc) 5.11.1 (Author: Unity Open Source Project) ### 在專案中加入 Unity.Mvc


安裝套件完成後,會自動在 App_Start 加入 2 個檔案: `UnityConfig.cs` 及 `UnityMvcActivator.cs`
基本上所有的啟動功能它都做完了, 我們只要針對 `UnityConfig.cs` 這個檔案加入我們的註冊的類型即可 例如:   如果有忘記註冊的類型, 卻被使用到了, 即會出現以下的錯誤訊息 ### 程式用法 在 constructor 使用 interface 即會自動注入對應的實體 是不是很方便呢? 前人種樹, 後人乘涼, 現在只要專注去做自己該對應的相關程式, 多餘的設定全都被妥當安排了。 不知道是不是因為它太簡單使用了, 所以專案連 README 文件都沒寫 XD。 所以寫一篇用法以備不時之需, 個人覺得這是目前用過最簡易使用的套件了, 因為幾乎無痛使用啊!! 範例程式: [UnityMvcDemo1](https://github.com/onecentlin/UnityMvcDemo1) ### 相關連結 - [Unity.Mvc](https://github.com/unitycontainer/aspnet-mvc)

2019/11/16

[EF] 專案使用 Entity Framework 6.3.0 造成無法正確執行 Migration 動作

markdown ### 環境 - VS 2019 16.3.9 - Web Application (.NET Framework) 專案 - Entity Framework 6.3.0 ### 問題 在新建立的 Web 專案中, 採用 Entity Framework 6.3.0 版本, 執行 migration 時出現 Path 為空值的錯誤 ``` Enable-Migrations : Cannot bind argument to parameter 'Path' because it is null. ``` ### 暫時解決方法 降版至 EF 6.2.0 至於修正版本, 將會在 6.4.0 時修正並釋出, 所以 6.3.0 就直接跳過不要用吧!! ### 相關連結 - [EF 6.3.0 PMC commands throw ParameterBindingValidationException when Startup Project is a Web App](https://github.com/aspnet/EntityFramework6/issues/1290)

2019/08/09

[VSCode] 解決 Windows 10 1903 開啟 VSCode 內嵌 Terminal 終端機視窗跳出問題

markdown ### 問題 在 VS Code 開啟終端機時, 命令視窗是跳出式而非內嵌在 VS Code 內 ### 環境 - Windows 10 1903 版本 - VS Code 1.36.1 ### 解決方法 開啟設定,搜尋 conpty 把選項 Terminal > Integrated: Windows Enable Conpty 勾消即可 ### 參考連結 - [Terminal is always launching externally when ConPTY is turned on](https://github.com/microsoft/vscode/issues/73790) - [Intergrated terminal is pop out](https://github.com/microsoft/vscode/issues/78670) - [How do I get around the verified bug in Windows 1903 and launch the VSCode integrated terminal?](https://stackoverflow.com/questions/56154957/how-do-i-get-around-the-verified-bug-in-windows-1903-and-launch-the-vscode-integ)

2019/06/26

[Azure] 如何在 Azure Web App 啟用 PHP 模組

markdown ### 前言 最近有一個小小的 PHP 專案,資料量不大,我想直接用 Azure 的 Web App 搭用 SQLite 可攜式資料庫做應用 開個資料庫太殺雞用牛刀,而且資料庫開下去都是要 $$ 的 在部署上去之後發現 PDOException,當然就是連不上我要用的 SQLite 資料庫啦! 那該怎麼辦呢?找方法把缺的模組補上去吧! ### 環境 Azure Web App - Windows PHP 版本 ### 解決方法 1. 先在 site 資料夾下加上 ini 及 ext 的目錄,如圖: 下載 [PHP for Windows](https://windows.php.net/download/) 對應的版本 (NTS x86 版本), 需要加的模組 *.dll 上傳至 `ext` 目錄 其實我只需要 php\_pdo\_sqlite.dll 就好,但要試就一次定位吧~ 在 `ini` 目錄增加 `extensions.ini` 檔案 `extensions.ini` 內容如下 ```ini extension=d:\home\site\ext\php_pdo_sqlite.dll extension=d:\home\site\ext\php_sqlite3.dll ``` 2. 在組態設定部分,新增應用程式設定 名稱:`PHP_INI_SCAN_DIR`
 值:`d:\home\site\ini` 儲存後,記得重新啟動網站以載入模組設定 在主控台上鍵入: `php -m` 列出模組,有看到 `pdo_sqlite` 及 `sqlite3` 就表示正確載入囉! 終於網站可以確定讀到資料,完成! ### References - [在 Azure App Service 中設定 PHP](https://docs.microsoft.com/zh-tw/azure/app-service/web-sites-php-configure)

2019/06/12

[PHP] 解決連線 MySQL 錯誤訊息亂碼顯示問題

markdown ### 問題 一直以來這亂碼問題遇到的重覆不下 N 次,後來看到 `SQLSTATE[HY000] [2002]` 的錯誤代號,可以直覺反應就是連不到資料庫 Trace 出來的錯誤訊息實際是長這個樣子的,這是因為 MySQL 預設輸出錯誤訊息的是以 UTF-8 輸出,而非二進制的字符字串值從其字符集轉換為 UTF-8 就產生像以下的編碼狀況 ``` mysqli_connect(): (HY000/2002): \xb5L\xaak\xb3s\xbdu\xa1A\xa6]\xac\xb0\xa5\xd8\xbc\xd0\xb9q\xb8\xa3\xa9\xda\xb5\xb4\xb3s\xbdu\xa1C\r\n ``` 我們看顯示的樣子就像下圖,以使用者端來看就是有點不開心 ### 解決方法 用 mb\_convert\_encoding 的方式,先將取得編碼訊息轉成 utf-8 (以繁體中文的來說就是 big5) 如此就能正常顯示中文訊息啦 ### References - [iconv big5轉換utf8問題](http://sweslo17.blogspot.com/2012/04/big5-erpms-sql-local-cache-phpiconv.html) - [PHP: mb\_convert\_encoding](https://www.php.net/manual/en/function.mb-convert-encoding.php) - [MySQL: 10.6 Error Message Character Set](https://dev.mysql.com/doc/refman/5.7/en/charset-errors.html)

[PHP] 指定專案特定 PHP 版本以下載符合的 composer 套件

markdown ### 前言 一般來說,開發人員的機器總是會安裝最新版本的 PHP 來開發 但是總是會有久遠要維護的專案,而 PHP 版本可能也是久遠的舊版本 如果想透過 Composer 來管理套件,但又想要限制特定支援的安裝版本套件,那該怎麼辦呢? ### 問題 開發環境用 PHP 7.3,維護專案採用 PHP 5.6.1 在不變更開發環境的 PHP 版本之下,專案更新套件時會下載到最新的版本 ### 解決方法 在 Composer 有個方便的設定 `composer.json` 只要在 config 加上 platform 的 php 版本即可 ```json ... "config": { "platform": { "php": "5.6.1" } }, ... ``` 也可用指令方式來下命令達到一樣的效果 ``` composer config platform.php 5.6.1 ``` ### 更新 composer 修改 composer.json 後執行更新,即會做降版動作 ``` $ composer update ``` ### References - [Enforcing a PHP Version for Installed Composer Packages](https://andy-carter.com/blog/composer-php-platform)

2019/06/11

[VSCode] 用 VS Code 開啟 Laravel-Tracy 偵錯的檔案

markdown 以前寫過一篇是用 Sublime 開啟 Tracy 偵錯的檔案: [善用工具 -- Tracy 讓 PHP Debug 變簡單了](https://devmanna.blogspot.com/2015/10/tracy-tracy-php-debug.html) 現在都用 VS Code 或 PhpStorm 來寫 PHP 專案 來記錄一下怎麼使用 VS Code 來開啟 Laravel-Tracy 偵錯到的檔案 ### 環境 - Laravel-Tracy 1.8.23 - VS Code 1.35.0 ### 編輯器設定 Protocol: `vscode://file/%file:%line` [Tracy](https://tracy.nette.org/en/) 的設定如下 ```php // Visual Studio Code Tracy\Debugger::$editor = 'vscode://file/%file:%line'; ``` [Laravel-Tracy](https://github.com/recca0120/laravel-tracy) 的設定如下 (`config/tracy.php`) ### 瀏覽器 以下為各個瀏覽器用 VS Code 來開啟檔案的對話視窗 Microsoft Edge Chrome Firefox ### References - [How to open a file in editor from Tracy?](https://tracy.nette.org/en/open-files-in-ide) - [Laravel-Tracy](https://github.com/recca0120/laravel-tracy)

[Kotlin] 第一支 Hello World

markdown Kotlin 快速入門第一發: 一定要來寫一下 Hello World ### 環境 - Windows 10 - Java SDK 1.8 - Kotlin Compiler v1.3.31 ### Command Line Compiler 下載 [Command Line Compiler v1.3.31](https://github.com/JetBrains/kotlin/releases/tag/v1.3.31) 下載解壓後指定系統環境路徑至 `kotlinc/bin` 確認版本指令: ``` $ kotlinc -version ``` 輸出如下就表示可以正確執行 CLI ``` info: kotlinc-jvm 1.3.31 (JRE 1.8.0_152-b16) ``` ### 建立第一支程式 建立一個 `hello.kt` 檔案 ```java fun main(args: Array) { println("Hello, World!") } ``` 編譯檔案 ``` $ kotlinc hello.kt -include-runtime -d hello.jar ``` 執行 ``` $ java -jar hello.jar ``` 輸出結果 ``` Hello, World! ``` 很久沒寫 Java,只是最近一直聽到 Kotlin 就來玩一下~ ### References - [Working with the Command Line Compiler](https://kotlinlang.org/docs/tutorials/command-line.html)

2019/06/09

[ASP.NET MVC] 解決 DirectoryNotFoundException 找不到路徑 bin\roslyn\csc.exe 的問題

markdown ### 前言 事情發生在 clone 專案編譯執行後發生的。以前曾經也發生過,但不記錄還是會忘了解法,趁現在遇到了,快記一下! ### 問題 ASP.NET MVC 專案在 git clone 下來編譯後執行網站出現:System.IO.DirectoryNotFoundException: 找不到路徑 'bin\roslyn\csc.exe' 的一部分 ### 解決方法 開啟專案 `*.csproj` 檔,加上 Target 的 AfterTargets 設定
### 參考 - [Could not find a part of the path … bin\roslyn\csc.exe](https://stackoverflow.com/questions/32780315/could-not-find-a-part-of-the-path-bin-roslyn-csc-exe) - [找不到 roslyn\csc.exe ?!](https://blog.yowko.com/missing-roslyn-csc/) - [Web API找不到 bin 底下的 roslyn csc.exe ?](http://marcus116.blogspot.com/2018/11/net-web-api-bin-roslyn-cscexe.html)

2019/03/14

[.NET] 用 Ical.Net 建立 iCalendar ics 日曆數據交換檔案

markdown 今天在專案中要產生 *.ics 的日曆數據交換檔案提供下載 打鐵趁熱記錄一下,以免又要石沈大海 目前採用的是在 NuGet 的 [Ical.Net](https://www.nuget.org/packages/Ical.Net/) 套件, 版本 v4.1.10 建立 CalendarEvent 超簡單
*.ics 內容如下
在 Windows 10 的行事曆開啟 *.ics 的呈現內容
### 範例程式 (採用 Web API)
### 參考資料 - [WiKi - iCalendar](https://zh.wikipedia.org/wiki/ICalendar) - [NuGet - Ical.Net](https://www.nuget.org/packages/Ical.Net/) - [Ical.Net Wiki](https://github.com/rianjs/ical.net/wiki)

2019/02/22

[ASP.NET MVC] 解決 SqlException 錯誤: 此憑證鏈結是由不受信任的授權單位發出的。

markdown 在佈署網站時總會遇到一些眉眉角角的問題 今天到客戶要求的主機上佈署網站,出現:「此憑證鏈結是由不受信任的授權單位發出的。」 的錯誤訊息

**訊息:[SqlException (0x80131904): 與伺服器的連接已成功建立,但在登入程序時發生錯誤。 (provider: SSL Provider, error: 0 - 此憑證鏈結是由不受信任的授權單位發出的。)]** 看起來資料庫連線沒問題,只是在登入步驟出了差錯。SSL Provider 提供重要線索,首先檢查連線字串~ 原本測試站是用 Azure 的 Database 服務,連線字串包含 Encrypt=True;TrustServerCertificate=False;,但客戶主機不適用,拿掉就可以正常連線了! 除錯任務完成,特此記錄一下!

2019/01/22

[Markdown] 用 Markdown 寫 blogger 文章

markdown # 測試在 Blogger 用 Markdown 寫文 ``` console.log("Hello Markdown Syntax"); ``` 記得撰寫用 HTML 並在第一行上加上 markdown ## 本站採用的語法
### 參考連結 - [在 blogger 貼漂亮 code 的方法(使用 markdown 和 prettyprint)](http://etrex.blogspot.com/2017/03/blogger-code-markdown-prettyprint.html)

2019/01/17

[VS Code] 如何整合設定 PHP 的開發環境至 Visual Studio Code

最近在帶 Laravel 工作坊,有許多學員為非程式開發人員,在入門程式開發的過程中。要把開發環境設定完成,若不透過手把手帶領,可能要繞很大圈才有辦法完全設定完畢。

由於 Laravel 這個框架的底程程式語言為 PHP。就以 PHP 的開發環境來跟 Visual Studio Code 做整合介紹。

目的


以 Visual Studio Code 為我們整合的開發環境:Git, Terminal, PHP 的整合設定

這次介紹主要以 Windows 的作業系統平台來做範例。當然大多數的 Visual Studio Code 設定也適用於 Mac,只是在 Mac 的設定上會少很多 (主要是 Terminal 以 bash 為主,PHP 及 Git 的路徑設定在安裝完時已經 Ready 了)

環境

 https://www.laravel-dojo.com/opensource/wagon