前回はCodesysを使ってどうやってRapbserryからOPCUAサーバを立ち上げる方法を書きました。もしもう一度みたいならこちらへ:
今回セキュリティ証明書を使うにはどうすればよいのか説明します。
OPC協会(2017年のもので少し古いかもしれませんが)によりますと、
トランスポート層のセキュリティ
data:image/s3,"s3://crabby-images/549f2/549f2b98aff13a84c8b92698ddaaaf8f88fb83fe" alt=""
アプリケーション層のセキュリティ
data:image/s3,"s3://crabby-images/af9fa/af9fa88f450b43b844802812a61be262f10f0309" alt=""
https://jp.opcfoundation.org/wp-content/uploads/sites/2/2017/12/OPCDay2017_04_OPC_UAsec.pdf
実装
Codesysを開いて、View>Security Screen。
data:image/s3,"s3://crabby-images/a1888/a1888d840842a16d20c5fc5742471135ac98bf2f" alt=""
本来ならここでUser、Project以外に”Devices”という3つ目の設定Tabがありますが、このリングでPackageをダウンロードしインストールおねがいします。
https://store.codesys.com/codesys-security-agent.html?___from_store=default&___store=en
data:image/s3,"s3://crabby-images/8bd83/8bd8384a41611c1ab804d339e1b9f6bc323f3135" alt=""
こっちらはCodesysで新しいPackageダウンロードする方法です。
インストール完了し、再起動したらView>Security Screenで”Devices”という3つ目のTabが見えました。
data:image/s3,"s3://crabby-images/eac6e/eac6e2264b7c2e7c00787e3e91fc72bb7639e9e7" alt=""
DevicesのTabをクリックし、緑のぐるぐるICONでRefreshします。
data:image/s3,"s3://crabby-images/516d8/516d8c7c3738d10c588444535b99355225f5df91" alt=""
もし見つからないのであれば、まずActive Pathがあってるかどうか確認してください。
次は、DevicesのTreeを展開し>OPC UA Server(Not available0を選んで、数字3にあるICONをクリックします。
data:image/s3,"s3://crabby-images/04b9a/04b9a78f1dd4e530241a43670a49fa29e38c02ab" alt=""
Certificate Settingsの画面が出てきます。こことりあえず2048Key Lengthで、Validty periodは365日にします。
data:image/s3,"s3://crabby-images/9f7fa/9f7fa688cfaa168586ed762d14f3c4bc1f95ffef" alt=""
そうすると、証明書が作りました。
data:image/s3,"s3://crabby-images/a3dc0/a3dc08f525d897aced9ae9860db40f3c2f7dc535" alt=""
最後はPi3をリセットしてください。多分ですが、私がテストした場合は再起動でも次で書いてる-UAExpertで確認するとき、Basic256のConnection出てこれなかった。そしてApplicationを”全削除”しDownload入れ直ししたらOKになりました。うん~わかりませんね。一時間かかりました。WTF。
data:image/s3,"s3://crabby-images/cc179/cc1793b492c3a7d0bc3fd604df1db05dc3718b40" alt=""
テスト
次はUaExpertを使って検証します。
Basic256Sha256 – Sign & Encrypをあるかどうかを確認します。もしなかったらApplicationをもう一度全削除しDownloadをおねがいします。
data:image/s3,"s3://crabby-images/33a30/33a3097c94d382dfdcaec10201f7ab47f2795348" alt=""
Basic256Sha256 – Sign & Encryptを選びます。
data:image/s3,"s3://crabby-images/62895/6289571c3963bf6a2016ac60030ca7443bf9d054" alt=""
Server名選んで、Connect。
data:image/s3,"s3://crabby-images/3ee27/3ee27fe7ec7776176a350c079ed7079265e2c4db" alt=""
しばらく待っていたら、Errorが出てきます。
うん?BadCertificateTimeInvalid?
data:image/s3,"s3://crabby-images/9cee2/9cee26e6d48c2f0fff9bd7bd43732584d4ffb571" alt=""
少し調べましたが、どうやら私のRaspberryの時間があってないみたい。
このリングで詳しく教えてくれます。まぁ、一番早いのはRaspberryをインタネットを接続すること、ですね。
sudo date -s "Thu Aug 9 21:31:26 UTC 2012"
https://www.raspberrypi.org/forums/viewtopic.php?t=13313
そうしてもう一度Certificationを作り直します。うん~先一回め作ったとき証明書の日付がおかしいなと思ったがきをしなかった…
data:image/s3,"s3://crabby-images/ef8b3/ef8b34d74bd5e662ec5341514e46d8c5a789b016" alt=""
もう一度接続したら、今度はBadCetificatUntrustedのエラーが出てきます。
Trust Server Certificateをクリックし、OK。
data:image/s3,"s3://crabby-images/9a4f1/9a4f13e502f93c0c5608c7422608f8ea7b3e4891" alt=""
最後はView>Securityもう一度みて、Quarantined Certificateのところみたら、先UaExpertで自分の証明書がみえます。
data:image/s3,"s3://crabby-images/693f9/693f9a83b47b02949c830acf5f81d7f2de781161" alt=""
この証明書を選んで、Trusted Certificateほうへ引っ張ります。
data:image/s3,"s3://crabby-images/4f2bb/4f2bbedf01dc114e51e7a29b6d06f4ecfc9bbe8e" alt=""
こんな感じでOKです。
data:image/s3,"s3://crabby-images/14356/143564bb6bc76a663a07067bb17ba8b0da63dcb1" alt=""
最後もう一度ConnectしたらOKになりました。なかのNodeもみえるようになります。
data:image/s3,"s3://crabby-images/83a87/83a878e41f046139c133411d1210b5c2fb5cb3ac" alt=""
お疲れ様ですー