2022-01-26

Mobile Safari 簡繁轉換

iOS 15 後,Safari 支援 Extension,而最近發現 Userscripts 支援 iOS 的 safari,立馬裝來試試。

之前同文堂有提供繁簡轉換的 js ,但是對於動態的內容不會自動即時轉換,因此我就調整了一下,針對動態插入畫面的內容也進行轉換。

主要是加上:document.addEventListener("DOMNodeInserted", convert_trad, true); 來處理動態內容。  

設定後,就不用再去看殘體字了,這個 script 沒有對用詞進行轉換,不過對我來說已經夠用了。

 Userscripts 可以使用 icloud 當放 js 的目錄,因此可以利用 icloud 來同步電腦上的 script。

2022/02/11 Update 

優化動態內容轉換處理方式,改用 MutationObserver 來處理,避免造成 Google docs 操作異常。


2022-01-22

設定 iPhone 假的 GPS 位置

 libimobiledevice 是一個與 iDevice 溝通的工具包,裡面包含了不少好用的工具,而今天我要用的是設定 iDevice GPS 的工具:idevicesetlocation


安裝方式:

    brew install libimobiledevice

使用方式:

iPhone 接上電腦後,執行:

    idevicesetlocation -- 24.986901945818218 121.53703021237283

後面的兩個數字,前面是緯度(Latitude),後面是經度(Longitude),執行完後,裝置上的位置就會移到該地方。
重置方式:
    idevicesetlocation reset 
 
 

2020-03-29

利用免費資源 Oracle Cloud / AdGuard Home / Surge 在手機上擋廣告



最近看到 AdGuard Home 可以架 DNS Server 來擋廣告,又發現 Surge 可以改 iOS 行動網路連線的 DNS,因此想到利用 Oracle Cloud 的免費 vpc 來搭建相關服務來擋手機上的廣告。




環境準備: 

Oracle Cloud

我是採用 ubuntu 的 image, 建立完用,可以利用 ubuntu 帳號 ssh 登入去操作。



AdGuard Home

可參考『是時候裝一套 AdGuard Home 全局擋廣告神器了!』 進行設定
我的設定檔如下: 

Surge

  1. 設定 DNS ,指到 ubuntu 的 ip
  2. 啟動 Surge

設定完的成果

 

 

 

 

 

 

 

 

各國的 IP CIDR 格式可以參考:
https://github.com/herrbischoff/country-ip-blocks

2019-06-09

遠端連線相關工具

因為偶而需要當工具人幫忙修電腦,因此需要一些連線工具,集中起來以免不時之需。
  1. anydesk
  2. WaykNow
  3. 向日葵遠端
  4. TeamViewer
  5. Chrome 遠端桌面
  6. gbridge
  7. Ultra VNC
  8. PCAnywhere
  9. Radmin VIewer 
SSH
  1. mobatek 
  2. putty

2018-01-27

VSCode 有用的 Extension

Visual Studio Code 最近拿來開發 React Native, 記錄一下目前用的 Extension

2014-09-21

PDF 簡轉繁

現在一些技術文件,簡體中文比正體中文多很多,因為實在看不慣簡體字,因此通常會將簡體字轉正體字再看。在瀏灠器上可以使用同文堂, PDF 就沒有可以在瀏灠時直接做繁簡轉換的程式,因此找了一個工具,先把 PDF 內容轉成正體字,再放到 PDF Reader 裡開啟。

使用工具環境:

安裝步驟

sudo easy_install pdfrw
sudo easy_install fonttools
sudo easy_install chardet
brew install opencc

ruby -e "$(curl -fsSL https://raw.github.com/Homebrew/homebrew/go/install)”
brew install opencc
sudo mkdir -p /usr/share/fonts/truetype/droid/
sudo curl https://raw.githubusercontent.com/android/platform_frameworks_base/master/data/fonts/DroidSansFallbackFull.ttf -o /usr/share/fonts/truetype/droid/DroidSansFallbackFull.ttf
git clone https://github.com/tjwei/translatePDF.git
cd translatePDF

在 translatePDF 目錄下,執行以下指令即可轉換 pdf 的內容了:

python2.7 tpdfrw.py /Users/scott/Downloads/Architect.pdf

註:
如 pdf 檔被鎖定的話,是無法轉換的。

2014-09-05

如何追查 SQL Server 的 Deadlock

最近有個客戶常遇到 SQL Server 的 Deadlock 問題,查了一下,追踨 Deadlock 有兩個做法(實際應該是一樣的):
  1. 使用 SQL Server Profiler 去記錄
  2. 直接下 SQL 新增追踨

以下是使用 SQL 指令追踨的方法:

  1. 建立追踨 Deadlock (假定追踨檔是要存在 D:\DbLog\ 下)
     -- 運行下述語句後,每當SQL Server中發生死鎖事件,都會自動往文件e:\DbLog\deadlockdetect.trc 中插入一條記錄。
     -- 定義參數 
     declare @rc int
     declare @TraceID int
     declare @maxfilesize bigint
     set @maxfilesize = 5
     -- 初始化跟蹤 
     exec @rc = sp_trace_create @TraceID output, 0, N'E:\DbLog\deadlockdetect', @maxfilesize, NULL
     --    此處的e:\dblog\deadlockdetect是文件名(可自行修改),SQL會自動在後面加上.trc的擴展名 
     if (@rc != 0) goto error 
     -- 設置跟蹤事件 
     declare @on bit
     set @on = 1
     --下述語句中的148指的是locks:deadlock graph事件(參見sys.trace_events),12指的是spid列(參見    sys.trace_columns) 
     exec sp_trace_setevent @TraceID, 148, 1, @on
     exec sp_trace_setevent @TraceID, 148, 4, @on
     exec sp_trace_setevent @TraceID, 148, 11, @on
     exec sp_trace_setevent @TraceID, 148, 12, @on
     exec sp_trace_setevent @TraceID, 148, 14, @on
     exec sp_trace_setevent @TraceID, 148, 26, @on
     exec sp_trace_setevent @TraceID, 148, 41, @on
     exec sp_trace_setevent @TraceID, 148, 51, @on
     exec sp_trace_setevent @TraceID, 148, 60, @on
     exec sp_trace_setevent @TraceID, 148, 64, @on
     -- 啟動跟蹤 
     exec sp_trace_setstatus @TraceID, 1
     -- 記錄下跟蹤ID,以備後面使用 
     select TraceID = @TraceID
     goto finish 
     error: 
     select ErrorCode=@rc
     finish: 
     go
    
  2. 當發生 Deadlock 後,去查看 deadlockdetect.trc 是哪些 SQL 有問題 (結果中的TextData列即以XML的形式返回死鎖的詳細信息。 )
     select fn_trace_gettable('e:\DbLog\deadlockdetect.trc', 1)
    
  3. 查詢、暫停和停止服務器端跟蹤
    查詢目前有哪些 Traces 正在執行
     SELECT * FROM sys.traces
    
    暫停某個 Trace
     -- 第一個參數表示TraceID,即步驟1中的輸出參數(或是從 sys.traces 查詢得到)。第二個參數表示將狀態改為0,即暫停
     exec sp_trace_setstatus 2, 0
    
    中止某個 Trace
     -- 第一個參數表示TraceID,即步驟1中的輸出參數(或是從 sys.traces 查詢得到)。第二個參數表示將狀態改為2,即停止
     exec sp_trace_setstatus 2, 2
    
  4. 在 Deadlock 的情況下,也可以直接查詢目前正在執行的 SQL
    SELECT sqltext.TEXT,req.session_id,
     req.status,
     req.command,
     req.cpu_time,
     req.total_elapsed_time,
     s.host_name,
     s.login_time,
     s.login_name
    FROM sys.dm_exec_requests req
     CROSS APPLY sys.dm_exec_sql_text(sql_handle) AS sqltext
     INNER JOIN sys.dm_exec_sessions s ON req.session_id = s.session_id
    where DB_NAME(req.database_id) = '資料庫名稱'
    

2014-07-24

Windows 2008 單一網卡架 VPN Server

因為偶而需要去大陸出差,需要一個跳板可以突破 GFW ,之前都是利用 SSH Tunnel ,不過在 ipad 上無法使用,因此找了台主機來架 VPN Server。網路上找到的範例教學大多是利用兩張網卡,研究了好久才知道 Windows 2008 是要怎樣設定,步驟如下:

  1. 新增路由及遠端存取
     
  2. 選擇自定設定
     
  3. 選取『VPN存取』及『NAT』
     
  4. 完成新增
     
  5. 設定  DHCP 發送位址範圍
  6. 設定 NAT,選取區域連線
  7. 選取『連線到網際網路的公用介面』及『在這個介面上啟用NAT』
     
  8. 完成後,即可利用 PPTP 的方式 VPN 連線到此台電腦,利用此電腦的網路上網了  

2014-03-18

iOS 7.1 無法利用 http 佈署企業 app

目前開發企業內部使用之 app ,iOS 7 之前,用企業 provision 可以將程式打包成 ipa 檔,利用 itms-services:// 開頭的網址搭配一個描述檔 (plist) 來安裝 ipa 檔,如
itms-services://?action=download-manifest&url=http://www.test.com/app.plist

可是到了 iOS 7.1 之後,就會發生:無法安裝應用程式,因為「www.test.com」的憑證無效。

上網查了一下,才發現原來 iOS 7.1 之後 plist 檔一定要在認可的 https 協定下載,目前可行的方法有:

  1. 為網站購買 SSL 憑證,改走 https 的方式進行安裝
  2. 使用 openssl 自簽憑證,iDevice 上要先匯入自簽根憑證才可使用
  3. 將 plist 檔放在別人提供的 https 空間(如 dropbox),再利用此種模式下載安裝
第一種方式就不用講了,第二種方式的處理方式如下:
  1. 產生自簽根金鑰
    openssl genrsa -out myCA.key 2048
  2. 產生自簽根憑證
    openssl req -x509 -new -key myCA.key -out myCA.cer -days 3650 -subj /CN="小虫CA"
  3. 產生網站金鑰
    openssl genrsa -out mycert1.key 2048
  4. 產生 CSR
    openssl req -new -out mycert1.req -key mycert1.key -subj /CN=www.test.com
  5. 利用自簽根金鑰
    openssl x509 -req -in mycert1.req -out mycert1.cer -CAkey myCA.key -CA myCA.cer -days 365 -CAcreateserial -CAserial serial
  6. 網站使用 mycert1.key 及 mycert1.cer 來加密,iDevice 先匯入 myCA.cer 即可利用 https 連線到網站上了
  7. 再利用以下網址即可進行網路安裝 ipa
    itms-services://?action=download-manifest&url=https://www.test.com/app.plist
第三種方式,可以將 plist 放置 Dropbox 上,步驟如下:
  1. 將 plist 檔放置 dropbox 下
  2. 取得 plist 檔的分享路徑,如
    https://www.dropbox.com/s/jwwu4p1kctqenva/app.plist
  3. 將 www.dropbox.com 改為 dl.dropboxusercontent.com,如
    https://dl.dropboxusercontent.com/s/jwwu4p1kctqenva/app.plist
  4. 將 app 安裝的網址改為使用第三點的 link 即可,如:
    itms-services://?action=download-manifest&url=https://dl.dropboxusercontent.com/s/jwwu4p1kctqenva/app.plist

2014-01-23

如何在 Genymotion 模擬器上新增 Google Framework

新版的 Genymotion 因為版權問題,android 模擬器中不含 Google Framework ,目前有兩種做法:
Genymotion  2.0.0 版後因正式營利,所以 2.0.0 版後的 ova 內不包括有版權的 gapps 及 ARM library,目前的做法有兩種:

  1. 使用舊版含 gapps 的 ova : 官方載點似乎已經找不到了,要各憑本事找
  2. 在新的 ova vm 中安裝 gapps 及 ARM library
安裝步驟如下:
  1. 下載相關檔案:
    ARM Translation Installer v1.1
    Google Apps for Android 4.3
    Google Apps for Android 4.2
    Google Apps for Android 4.1
  2. 開啟 Genymotion 模擬器,解鎖到 home screen
  3. 將 Genymotion-ARM-Translation.zip 拖拉進 vm 的視窗中,進行安裝,裝完後將 vm 重新開機
  4. 將對應的 Gapp檔案拖拉進 vm 中,進行安裝,裝完後再次重開機,就會有 Google play Store 可以使用了。

參考:
http://forum.gamer.com.tw/C.php?bsn=23805&snA=165002
http://stackoverflow.com/questions/17831990/how-do-you-install-google-frameworks-play-accounts-etc-on-a-genymotion-virtu

2013-02-03

Titanium sdk 如何利用 andriodvm 來加速測試開發

最近利用 Titanium studio 來開發 android app ,發現 android 模擬器真是非常的慢,上網找了一下資料發現 AndroidVM 這個好物,它利用 VirtualBox 來執行,整個速度真是快的不得了。

安裝檔案:

  1. VirtualBox
  2. AndroidVM
    vbox86p : 手機版, 預設解析度 480×800
    vbox86t : Tablet 版,預設解析度 1024×600
    vbox86tp : Tablet 版,但有電話的功能,預設解析度 1024×600
    gapps : 代表包含 Google 相關服務 (有 Google Play)
    houdini: 代表包含 Arm emulation (AndroidVM 是跑在 x86 上,所以反過來需要去模擬 Arm)
安裝步驟可參考:Android Development with AndroVM

那在 Titanium Studio 中要如何直接部署它並且在上面 Debug 呢?
首先,連結 androidVM

要修改 Titanium SDK 的 source code:
~/Library/Application Support/Titanium/mobilesdk/osx/2.1.4.GA/android/builder.py
將 run_adb(self, *args) 的第三行 command.extend(self.device_args) 註解掉,即可利用 Titanium Studio 的 Android Device 功能直接佈署到 device 中進行測試及除錯了。
如果要查看 AndroidVM 中 Titanium 的 log,可以在 Console 環境下執行:
adb logcat | grep -G '\(TiAPI\)\|\(TiApp\)'

2013-01-04

利用 Groovy + jsoup 來擷取網頁內容

今天一位朋有希望我幫它把某人在 yahoo 拍賣上的物品清單抓下來,剛好讓我試試利用 Groovy 及 jsoup 來處理:

參考:
http://blog.lyhdev.com/2012/12/groovy-jsoup-java-html-parser.html

2012-11-19

如何在 OSX 中開啟多個 Eclipse


在 OSX 環境中,預設 Eclipse 只能開啟一個,當我們需要同時間開啟兩個 workspace 時,就需要以指令的方式去開啟另外一個 Eclipse instance:

  1. 開啟 Terminal 
  2. 切換到 Eclipse 安裝路徑
    cd /Application/eclipse
  3. 下指令開啟 Eclipse
    ./eclipse &
    或是
    open -n Eclipse.app

參考:
http://stackoverflow.com/questions/118243/open-multiple-eclipse-workspaces-on-the-mac

2012-07-25

如何利用 script 來自動切換 OSX 的網路位置

OSX 有個很方便的功能,可以針對不同的網路環境設定位置 profile,利用切換網路位置來快速調整網路設定。雖然說很方便,但是,每次都要進到網路設定去改,還是有點麻煩。

還好 OSX 有指令可以用來調整,因此我們可以利用指令取得目前使用的無線網路 SSID 來辨斷要切換到哪個網路位置去:

參考:
http://hints.macworld.com/article.php?story=2005010613401823
http://stackoverflow.com/questions/4481005/get-wireless-ssid-through-shell-script-on-mac-os-x

2012-06-29

如何開啟 Mac OS X 的 tftp server

執行以下兩個指令就會啟動 OSX 內建的 tftp server 了:

sudo launchctl load -F /System/Library/LaunchDaemons/tftp.plist
sudo launchctl start com.apple.tftpd

tftp 預設的文件目錄為:
/private/tftpboot

可以修改 /System/Library/LaunchDaemons/tftp.plist 來改變目錄位置(要重啟 tftp server)。


參考來源

2012-03-03

iPhone 如何利用 socks proxy 上網(不需 jailbreak)

iPhone iPad 本身上網的設定並沒有可以利用 socks proxy 的方式,所以我們可以利用自動組態檔的方式來處理,方法如下:
  1. 在電腦(如 192.168.11.1)建立一個 socks proxy ,如利用 ssh:
    ssh -N -g -D 1080 某主機ip
  2. 在一台 web server 上放置一各自動組態檔,內容如下:
    function FindProxyForURL(url, host) {
      return "SOCKS
    192.168.11.1:1080";
    }
    紅字的部份是對應 proxy 主機的 ip
  3. 在 iphone 上使用此自動組態檔即可,如:
    http://192.168.11.1/mysupersecretproxy.pac




參考:
http://snipplr.com/view/16563/how-to-connect-to-a-socks-proxy-from-an-unjailbroken-iphoneipod-touch/
http://thireus.dareyourmind.net/index.php/thireus-home-news/8-general-announcement/112-pac--ssh-tunneling--iphone--success-
http://thireus.dareyourmind.net/index.php/iphone-hacks/115-how-to-get-socks-proxy-ssh-tunneling-to-work-on-a-jailbroken-iphoneipod-touchipad

2011-09-23

Git 與 subversion 透過 http proxy

小弟公司對外都要透過 proxy 才能存取,而我又常需要抓取外部 svn 或 github 中的程式碼下來參考,因此研究了一下如何設定 proxy 讓 git 與 svn 使用。


環境:
  • MacBook Pro with OSX Lion 10.7.1
  • svn, version 1.6.16
  • git version 1.7.4.4
Subversion

編輯 ~/.subversion/servers 檔案,設定 globe 的 http-proxy-host 與 http-proxy-port

在 svn checkout 時改用 http 或 https 協定即可:
svn checkout http://flot.googlecode.com/svn/trunk/ flot-read-only

Git

設定好環境變數 http_proxy 與 https_proxy 即可。


在 git clone 時改用 http 或 https 協定即可:

git clone http://github.com/carlhuda/janus.git ~/.vim


參考
http://realchecko.blogspot.com/2007/05/git-over-http-proxy.html

利用 VirtualBox 附的 VBoxManage 將vmdk/vhd轉換為VDI格式

VBoxManage clonehd source.vmdk target.vdi --format VDI

  • clonehd : 告訴 VBoxManage 要複制虛擬硬碟檔案
  • source.vmdk : 來源檔案
  • target.vdi : 目地檔案
  • --format VDI : 指定目地檔案的格式,來源檔案的格式似乎會自動判斷 
轉換完後就可以在 virtualbox 中建立新的虛擬環境,並使用 target.vdi 進行開機使用了。

參考:
    http://blog.tenyi.com/2009/12/convert-from-vmdkvhd-to-vdi-format.html
    http://nfolamp.wordpress.com/2010/06/10/converting-vmdk-files-to-vdi-using-vboxmanage/

2011-09-09

CSS 解決網頁連續英數字文字太長而導致版面撐大的問題

一直以來,當網頁遇到連續的英文數字時,總是會無法斷行造成版面被撐大,以前的做法都是在文章中插入 br 來強制換行,今天終於找到利用 css 就可以控制版本並強制換行了。

一開始找到的方式是在 css 加上
	word-wrap: break-word;
	word-break: break-all;


結果發現在 Internet Explorer 上是 ok 的,在 Firefox 上是無效的。

後來又找到另外一個方法,在 css 上加上:
	word-wrap:break-word;
	word-break:break-all;
	-moz-binding: url('./wordwrap.xml#wordwrap');
	overflow: hidden;

然後再利用 wordwrap.xml 來處理:

結果發現這個方式 firefox 最新版本已經不能用了。

最後找到的方法,在 css 上加上:
	word-wrap:break-word; 
	overflow: auto;
	width: 600px;


這樣 ie 與 firefox 都能使用了。
範例: 結果
data:text/html;charset=utf-8;base64,Q29uZ3JhdHVsYXRpb25zISBZb3UndmUgZm91bmQgdGhlIGhpZGRlbiBtZXNzYWdlIQ0KDQpUbyBjbGFpbSB5b3VyIHByaXplLCB2aXNpdCBodHRwOi8vZ2V0ZmlyZWZveC5jb20gdG9kYXkhDQoNCkZyZWUgYnJvd3NlciBpbiBldmVyeSBib3ghDQo%3D


參考:
http://www.minwt.com/?p=93
http://www.cnblogs.com/analyzer/articles/1285732.html
http://blog.longwin.com.tw/2008/06/css_word_wrap_fix_too_many_word_2008/
http://hacks.mozilla.org/2009/06/word-wrap/