Google Code Prettify

[C#]調用C++及Java方法實例詳解

C#可以直接引用C++的DLL和轉換Java寫好的程序。最近由於工作原因接觸這方面比較多,根據實際需求,我們通過一個具體例子把一個JAVA方法轉換成可以由C#直接調用的DLL。



C#調用c++
C#調用C++的例子網上很多,以一個C++的具體方法為例。
C++代碼
// 獲取一幀圖像數據
MVSMARTCAMCTRL_API int __stdcall MV_SC_GetOneFrame(IN void* handle, 
IN OUT unsigned char *pData , 
IN unsigned int nDataSize, 
IN OUT MV_SC_IMAGE_OUT_INFO* pstImageInfo);
// 結果數據緩存的上限
#define MV_SC_MAX_RESULT_SIZE (1024*16)
// 輸出幀的信息
typedef struct _MV_SC_IMAGE_OUT_INFO_
{
unsigned short nWidth; // 圖像寬
unsigned short nHeight; // 圖像高
unsigned int nFrameNum; // 幀號
unsigned int nFrameLen; // 當前幀數據大小
unsigned int nTimeStampHigh; // 時間戳高32位
unsigned int nTimeStampLow; // 時間戳低32位
unsigned int nResultType; // 輸出的消息類型
// 根據消息類型對應不同的結構體
unsigned char chResult[MV_SC_MAX_RESULT_SIZE];
unsigned int nReserved[8]; // 保留
}MV_SC_IMAGE_OUT_INFO 

C#代碼
/// <summary>
/// 獲得相機所拍照片
/// </summary>
/// <param name="handle"></param>
/// <returns></returns>
[DllImport("MvSmartCamCtrl.dll")]
public static extern int MV_SC_GetOneFrame(IntPtr handle, Byte[] pData, int nDataSize, out MV_SC_IMAGE_OUT_INFO pstDevInfo);
// 輸出幀的信息
[StructLayout(LayoutKind.Sequential)]
public struct MV_SC_IMAGE_OUT_INFO
{
public short nWidth; // 圖像寬
public short nHeight; // 圖像高
public int nFrameNum; // 幀號
public int nFrameLen; // 當前幀數據大小
public int nTimeStampHigh; // 時間戳高32位
public int nTimeStampLow; // 時間戳低32位
public int nResultType; // 輸出的消息類型
// 根據消息類型對應不同的結構體
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = 1024 * 16)]
public MV_SC_RESULT_BCR chResult;
[MarshalAs(UnmanagedType.ByValArray, SizeConst = 8)]
public int[] nReserved;
}


這樣我們把這個DLL放在程序根目錄下,就能實現DLL方法的調用。


C#調用JAVA方法

IKVM.NET是一個針對Mono和微軟.net框架的java實現,其設計目的是在.NET平臺上運行java程序。它包含了以下的組件:用.NET實現的java虛擬機,java類庫的.NET實現。
致力於在java和.NET之間交互的工具。

程序需求

我們有一個JAVA寫好的Demo,傳的參數是用Gzip進行壓縮傳到服務器的,代碼如下:

package Demo;

import java.io.BufferedReader;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.util.zip.GZIPInputStream;
import java.util.zip.GZIPOutputStream;
import org.apache.commons.httpclient.HttpClient;
import org.apache.commons.httpclient.methods.PostMethod;
import org.apache.commons.httpclient.params.HttpClientParams;
import com.Google.gson.Gson;

public class Demo
{

    public static String doPostClient(String json, String url)
    {
        HttpClient httpClient = new HttpClient();
        String rval = "";
        PostMethod postMethod = new PostMethod(url);
        try
        {
            Gson gson = new Gson();
            InputStream in = new ByteArrayInputStream(objectToByte(json));
            postMethod.setRequestBody(in);
            HttpClientParams params = new HttpClientParams();
            httpClient.setParams(params);
            httpClient.executeMethod(postMethod);
            byte[] b = postMethod.getResponseBody();
            String rtnData = http://www.cnblogs.com/kaoleba/p/(String) byteToObject(b);
            rval = gson.toJson(rtnData);
        } catch (Exception e)
        {
            rval="erro:"+e.getmessage();
        } finally
        {
            postMethod.releaseConnection();
        }
        return rval;
    }

    public static byte[] objectToByte(java.lang.Object obj)
    {
        byte[] bytes = null;
        ObjectOutputStream oo = null;
        try
        {
            ByteArrayOutputStream out = new ByteArrayOutputStream();
            GZIPOutputStream gzip = new GZIPOutputStream(out);
            gzip.write(obj.toString().getBytes("utf-8"));
            gzip.close();
            bytes = out.toByteArray();

        } catch (Exception e)
        {
            e.printStackTrace();
        } finally
        {
            if (oo != null)
            {
                try
                {
                    oo.close();
                } catch (IOException e)
                {
                    e.printStackTrace();
                }
            }
        }
        return bytes;
    }

    private static java.lang.Object byteToObject(byte[] bytes)
    {
        String obj = "";
        ObjectInputStream oi = null;
        try
        {
            ByteArrayInputStream bi = new ByteArrayInputStream(bytes);
            GZIPInputStream gzipi = new GZIPInputStream(bi);
            BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(gzipi, "UTF-8"));
            String line;
            while ((line = bufferedReader.readLine()) != null)
            {
                obj+=line;              
            }
        } catch (Exception e)
        {
            e.printStackTrace();
        } finally
        {
            if (oi != null)
            {
                try
                {
                    oi.close();
                } catch (IOException e)
                {
                    e.printStackTrace();
                }
            }
        }
        return obj;
    }

}
這個代碼我用C#改寫了,用HttpWebRequest的方式傳到服務器,服務器那邊Gzip解壓不了,查了原因是因為Java與C#的Byte類型值範圍不同,我們有兩種解決思路,一種是將這個JAVA做成webservice掛在服務器上,c#再去調用,第二種就是將這個方法編譯成可由C#直接調用的DLL,由於這個方法功能比較單一,我們選取了後者。

環境配置

IKVM.NET 下載後解壓得到BIN文件夾中的數據,用於JAR包轉換和基礎DLL。
IKVM.OpenJDK.ClassLibrary.dll用於C#程序接入。
下載地址:https://yunpan.cn/cBHTS5fXsIe9v 訪問密碼 0847。
將IKVM.NET的BIN文件夾的地址添加到環境變量。
計算機右鍵屬性--高級系統設置--高級--環境變量--在系統變量中找到PATH--將BIN文件夾的地址添加進去,
在CMD中輸入ikvmc 有幫助文檔說明環境配置成功。
Bin文件夾下的IKVM.OpenJDK.Core.dll,IKVM.Runtime.dll,IKVM.Runtime.JNI.dll和IKVM.OpenJDK.ClassLibrary.dll為公共DLL,所有轉換程序都需引用

轉換步驟

1.確定引用關系:
該Demo的結構如下:
Demo.jar 依賴於 commons-httpclient-3.1.jar 和 gson-2.4.jar
commons-httpclient-3.1.jar 依賴於 commons-logging-1.1.3.jar 和 commons-codec-1.6.jar
我們先將gson-2.4.jar,commons-logging-1.1.3.jar,commons-codec-1.6.jar 生成DLL,語法如下:
ikvmc JAR包物理路徑。
win7系統默認生成在C:\Users\Administrator 這個文件夾下
commons-httpclient-3.1.dll 生成語法如下:
ikvmc commons-httpclient-3.1.jar -r:commons-logging-1.1.3.dll -r:commons-codec-1.6.dll
我們將Demo打包的名字為JavaApi.Demo 這樣生成的 JavaApi.dll 生成語法如下:
ikvmc JavaApi.Demo.jar -r:commons-httpclient-3.1.dll -r:gson-2.4.dll
上面的文件都是相對應的物理路徑,然後將所有生成的DLL添加到C#項目中引用,包括之前的公共DLL,引用到項目中所有引用的DLL如圖:
這樣就可以直接在程序中使用這個java方法了
Demo.Demo.doPostClient(js, url);
第一個Demo java程序中的package名。
第二個Demo java程序中的class名。

以上所述是小編給大家介紹的C#調用Java方法實例詳解的全部敘述,希望對大家有所幫助,如果大家想了解更多內容敬請關註腳本之家網站!



資料來源: http://www.itread01.com/articles/1476133211.html

[C#]Windows 10 停用與啟用網路卡(連線)[手把手教程][原創]

當我們要停用或啟用網路連線的時候,手動的方式是用滑鼠點選畫面左下角的開始,再點選齒輪圖示






就可以進入到 Windows 設定的功能選擇畫面,我們選擇網路與網際網路





接著我們點選變更介面卡選項,就可以到網路連線的設定畫面了。








畫面中會出現很多的網路連線設定項目,你可以在你要變更設定的網路連線項目上按下滑鼠的右鍵,就會出現功能表。







功能表的第一項就是停用或啟用 用滑鼠點選它你就可以完成停用或啟用









接著我們進入到真正的主題,就是如何撰寫程式來停用或啟用網路連線,首先我們需要一個元件,這個元件的位置是在 C:\Windows\System32\hnetcfg.dll ,你需要先將它設定為參考 。







然後再將它設定為引用(using NETCONLib;),你就可以使用這個元件了,原始碼如下:




using System;

using NETCONLib;

namespace IC4 {
    class Program {
        static void Main(string[] args) {
            try {
                NetSharingManagerClass netSharingMgr = new NetSharingManagerClass();
                INetSharingEveryConnectionCollection connections = netSharingMgr.EnumEveryConnection;
                foreach(INetConnection connection in connections) {
                    INetConnectionProps connProps = netSharingMgr.get_NetConnectionProps(connection);
                    if(connProps.Name == "MyNetworkInterface") { //須設定成你自己的網路連線名稱
                        connection.Disconnect(); //停用網絡
                        connection.Connect();    //啟用網絡
                    }
                }
            }
            catch(Exception ex) {
                Console.WriteLine(ex.ToString());
            }
            Console.WriteLine("Press any key...");
            Console.ReadKey();
        }
        static void Enable(string interfaceName) {
            System.Diagnostics.ProcessStartInfo psi =
                   new System.Diagnostics.ProcessStartInfo("netsh", "interface set interface \"" + interfaceName + "\" enable");
            System.Diagnostics.Process p = new System.Diagnostics.Process();
            p.StartInfo = psi;
            p.Start();
        }
        static void Disable(string interfaceName) {
            System.Diagnostics.ProcessStartInfo psi =
                new System.Diagnostics.ProcessStartInfo("netsh", "interface set interface \"" + interfaceName + "\" disable");
            System.Diagnostics.Process p = new System.Diagnostics.Process();
            p.StartInfo = psi;
            p.Start();
        }
    }
}


說明:
先建立一個 "主控台應用程式" 的專案,再將我提供的程式複製到你的專案中。



 Disconnect() 就是停用
Connect() 就是啟用

你可以自由決定是要停用或啟用網路卡(連線)


在程式中有一行需要稍微注意一下

if(connProps.Name == "MyNetworkInterface") { //須設定成你自己的網路連線名稱


這一行程式中的 "MyNetworkInterface" 你必須將它改成你自已的網路卡(連線)的名稱,程式就可以將它停用或啟用。

[Facebook][ASP.Net]如何成為 Facebook 的開發人員-開發人員帳號(2)

你可以透過下列的網址申請你的開發人員帳號

https://developers.facebook.com/docs/apps/register?locale=zh_TW#developer-account

進入網頁畫面後點選下圖的按鈕 就可以進入申請的畫面



點選下一步繼續申請的操作



填寫你想要建立的應用程式名稱及你的聯絡電子郵件資料然後按下一步



如果畫面上有出現安全認證那麼你可以勾選你不是機器人然後按提交, 接著系統會問你以下何者最符合你的角色你可以依你的狀況去做選擇




在你選擇後系統就會進入歡迎使用 臉書開發人員主控版的畫面, 點選加入你的第一個產品




就可以完成你開發者帳戶的申請, 進入到開發者商品的設定畫面, 你可以在這個畫面中選擇你要開發的工作, 例如Facebook登入、 Account kit...等。