反編譯連接資料庫
『壹』 怎樣才能讓c#寫的程序不被反編譯
為了確保C#編寫的應用程序不易被反編譯,可以採用多種策略。首先,可以利用Visual Studio內置的混淆工具或第三方混淆工具(市面上有很多選擇)來處理編譯後的結果(如exe或dll文件)。混淆工具會通過對代碼進行重命名、重構和添加冗餘代碼等操作,使反編譯後的代碼變得難以理解。
具體操作時,可以在Visual Studio中選擇「生成」菜單下的「重新生成」選項,隨後選擇「混淆」進行處理。或者,若使用第三方工具,根據所選工具的文檔指引,將其與你的項目集成,確保在每次構建時自動運行混淆過程。
除了混淆技術,還可以考慮對敏感信息進行加密處理,例如API密鑰或資料庫連接字元串等。這樣即使有人獲得了反編譯後的代碼,也無法輕易獲取這些關鍵信息。在.NET框架中,可以使用.NET加密庫對敏感數據進行加密。
此外,定期更新你的應用程序和相關依賴庫也非常重要。新版本通常會修復已知的安全漏洞,並引入額外的安全措施。同時,保持良好的代碼實踐,如避免硬編碼敏感信息,使用安全的密碼存儲方式等,也能顯著提高應用的安全性。
值得注意的是,盡管採取了上述措施,仍無法完全防止所有類型的逆向工程。因此,除了技術手段,還需要考慮法律保護措施,例如版權和專利保護,以及與客戶簽訂保密協議等。
綜上所述,通過混淆代碼、加密敏感信息、更新軟體以及採用良好的編程實踐,可以有效提升C#程序的安全性,減少被反編譯的風險。
『貳』 C# VS2012 .Net 4.5 如何防止反編譯
你找下 數字簽名 怎麼用……
不過祈求代碼不會被反編譯是不可能的,我們追求的應該是難於反編譯和自身代碼的安全性,
從代碼設計代碼編寫技術的角度來避免發編譯後重要信息的泄露,比如資料庫連接是一定要用加密技術(例如MD5)加密以後在用的,絕對不可以將真實的可讀性強的連接串寫在代碼的任何位置
希望能幫到你……
『叄』 android怎麼鏈接資料庫mysql
有點多請耐心看完。
希望能幫助你,還請及時採納謝謝。
一.前言
android連接資料庫的方式有兩種,第一種是通過連接伺服器,再由伺服器讀取資料庫來實現數據的增刪改查,這也是我們常用的方式。第二種方式是android直接連接資料庫,這種方式非常耗手機內存,而且容易被反編譯造成安全隱患,所以在實際項目中不推薦使用。
二.准備工作
1.載入外部jar包
在Android工程中要使用jdbc的話,要導入jdbc的外部jar包,因為在java的jdk中並沒有jdbc的api,我使用的jar包是mysql-connector-java-5.1.18-bin.jar包,網路上有使用mysql-connector-java-5.1.18-bin.jar包的,自己去用的時候發現不兼容,所以下載了比較新版本的,jar包可以去官網下載,也可以去網路,有很多前人們上傳的。
2.導入jar包的方式
方式一:
可以在項目的build.gradle文件中直接添加如下語句導入
compile files('libs/mysql-connector-java-5.1.18-bin.jar')
方式二:下載jar包復制到項目的libs目錄下,然後右鍵復制過來的jar包Add as libs
三.建立資料庫連接
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_jdbc);
new Thread(runnable).start();
}
Handler myHandler=new Handler(){
public void handleMessage(Message msg) {
// TODO Auto-generated method stub
super.handleMessage(msg);
Bundle data=new Bundle();
data=msg.getData();
//System.out.println("id:"+data.get("id").toString()); //輸出第n行,列名為「id」的值
Log.e("TAG","id:"+data.get("id").toString());
TextView tv= (TextView) findViewById(R.id.jdbc);
//System.out.println("content:"+data.get("content").toString());
}
};
Runnable runnable=new Runnable() {
private Connection con = null;
@Override
public void run() {
// TODO Auto-generated method stub
try {
Class.forName("com.mysql.jdbc.Driver");
//引用代碼此處需要修改,address為數據IP,Port為埠號,DBName為數據名稱,UserName為資料庫登錄賬戶,Password為資料庫登錄密碼
con =
//DriverManager.getConnection("jdbc:mysql://192.168.1.202:3306/b2b", "root", "");
DriverManager.getConnection("jdbc:mysql://http://192.168.1.100/phpmyadmin/index.php:8086/b2b",
UserName,Password);
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
try {
testConnection(con); //測試資料庫連接
} catch (java.sql.SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
public void testConnection(Connection con1) throws java.sql.SQLException {
try {
String sql = "select * from ecs_users"; //查詢表名為「oner_alarm」的所有內容
Statement stmt = con1.createStatement(); //創建Statement
ResultSet rs = stmt.executeQuery(sql); //ResultSet類似Cursor
//<code>ResultSet</code>最初指向第一行
Bundle bundle=new Bundle();
while (rs.next()) {
bundle.clear();
bundle.putString("id",rs.getString("userid"));
//bundle.putString("content",rs.getString("content"));
Message msg=new Message();
msg.setData(bundle);
myHandler.sendMessage(msg);
}
rs.close();
stmt.close();
} catch (SQLException e) {
} finally {
if (con1 != null)
try {
con1.close();
} catch (SQLException e) {}
}
}
};
注意:
在Android4.0之後,不允許在主線程中進行比較耗時的操作(連接資料庫就屬於比較耗時的操作),需要開一個新的線程來處理這種耗時的操作,沒新線程時,一直就是程序直接退出,開了一個新線程處理直接,就沒問題了。
當然,連接資料庫是需要網路的,千萬別忘了添加訪問網路許可權:
<uses-permission android:name=」android.permission.INTERNET」/>
四.bug點
1.導入的jar包一定要正確
2.連接資料庫一定要開啟新線程
3.資料庫的IP一定要是可以ping通的,區域網地址手機是訪問不了的
4.資料庫所在的伺服器是否開了防火牆,阻止了訪問
————————————————
版權聲明:本文為CSDN博主「shuaiyou_comon」的原創文章,遵循CC 4.0 BY-SA版權協議,轉載請附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/shuaiyou_comon/article/details/75647355