• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆 - 64, 文章 - 11, 評論 - 12, 引用 - 0
            數據加載中……

            拆解一個RPC工具包

            由于我們現在所搭建的系統是基于分布式的系統,出于性能考慮決定基于RPC技術進行系統間的互操作與互通信。團隊內在使用一個已被封裝的RPC工具包,為什么稱它為工具包呢?因為它要生成兩個頭文件和兩個庫文件,其實它還會生成一些監時文件,只不過在它在生成靜態庫時就會把這些臨時文件刪除。這里逐個介紹它的戰果,頭文件就是接口方法的聲明和編譯控制選項,這里要談的是它的靜態庫文件,它是由idl生成的代理文件和存根文件并由再加入內存的分配和釋放的兩個函數及必要的入口函數來生成。為什么這樣說?首先可以通過編譯時出現的提示串。其次反匯編該文件。

            于我嘗試用該框架做一個helloworld,其間我經歷了幾次沮喪或者近乎冒火。靜下心來,仔細分析。首先查看服務端已開啟了偵聽,發現客戶端也已經發送,服務端也已到達,但就是沒有達到服務函數。最后問題定位在權限問,其實這個問題在我前面的博文中也已經詳談了。解決辦法:去除服務端對RPC的限制,其次反匯編該工具后發現了是服務端注冊接口函數,解決辦法在前面的博文中也已詳述,靜態hook也成,動態hook的方法也成。當前就用了第一種方法,最好的辦法還是不用它,而重新寫一個了。

            這個工具雖然讓我花了近一天來反匯編它,最后卻發現都是封裝的。但是其中的封裝的思想卻是值得借鑒的。這樣減輕一般用戶的使用難度,而且也搞得玄了些。哈哈,就怕我不暈。

            posted on 2011-03-04 13:41 Robertxiao 閱讀(864) 評論(0)  編輯 收藏 引用 所屬分類: RPC/COM/ATL散談

            久久国产三级无码一区二区| 精品国产热久久久福利| 久久婷婷人人澡人人爽人人爱 | 久久精品国产亚洲av麻豆小说| 亚洲va久久久噜噜噜久久狠狠| 久久精品国产亚洲AV大全| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 久久人做人爽一区二区三区| 久久国产免费直播| 国产精品美女久久久久AV福利| 久久九九久精品国产免费直播| www性久久久com| 精品久久久无码21p发布| 亚洲国产精品人久久| 久久夜色精品国产噜噜亚洲a| 久久se精品一区二区| 久久人人爽人人人人片av| 久久天天躁狠狠躁夜夜不卡| 国产婷婷成人久久Av免费高清| 欧美亚洲国产精品久久高清| 99久久人人爽亚洲精品美女| 久久精品99久久香蕉国产色戒 | 久久精品国产第一区二区| 久久ww精品w免费人成| 久久午夜福利无码1000合集| 精品国产综合区久久久久久| 97久久超碰国产精品旧版| 久久夜色精品国产噜噜噜亚洲AV| 色婷婷久久综合中文久久一本| 亚洲精品高清国产一久久| 国产精品18久久久久久vr | 久久www免费人成看国产片| 久久噜噜电影你懂的| 国产精品久久永久免费| 久久ZYZ资源站无码中文动漫| 久久久久久夜精品精品免费啦| 国产成人久久精品一区二区三区| 一本久久综合亚洲鲁鲁五月天| 亚洲人成无码网站久久99热国产| 午夜精品久久影院蜜桃| 中文精品99久久国产|