~~NOTOC~~
[[ssl_api]] > [[BS2_SetSSLHandler]]
----
===== BS2_SetSSLHandler=====
SSL통신을 설정합니다
\\
==== 함수 ====
#include "BS_API.h"
int BS2_SetSSLHandler(void* context, PreferMethod ptrPreferMethod, GetRootCaFilePath ptrGetRootCaFilePath, GetServerCaFilePath ptrGetServerCaFilePath, GetServerPrivateKeyFilePath ptrGetServerPrivateKeyFilePath, GetPassword ptrGetPassword, OnErrorOccured ptrOnErrorOccured);
==== 파라미터 ====
* [In] ''//context//'' : Context
* [In] ''//ptrPreferMethod//'' : SSL MethodMask 얻고자 할 때 호출되는 콜백 함수
* [In] ''//ptrGetRootCaFilePath//'' : Root CA 파일 경로를 얻고자 할 때 호출되는 콜백 함수
* [In] ''//ptrGetServerCaFilePath//'' : 서버 CA 파일 경로를 얻고자 할 때 호출되는 콜백 함수
* [In] ''//ptrGetServerPrivateKeyFilePath//'' : 서버 PrivateKey 파일 경로을 얻고자 할 때 호출되는 콜백 함수
* [In] ''//ptrGetPassword//'' : Password을 얻고자 할 때 호출되는 콜백 함수
* [In] ''//ptrOnErrorOccured//'' : 에러가 발생했을 때 호출되는 콜백 함수
==== 반환값 ====
성공적으로 수행될 경우 ''BS_SDK_SUCCESS''를 반환하고, 에러가 발생할 경우 상응하는 에러 코드를 반환합니다.
==== 샘플코드 ====
C++
int BS2Context::setSSLHandler()
{
int sdkResult = BS2_SetSSLHandler(context_, BS2Context::OnPreferMethod, BS2Context::OnGetRootCaFilePath, BS2Context::OnGetServerCaFilePath, BS2Context::OnGetServerPrivateKeyFilePath, BS2Context::OnGetPassword, BS2Context::onErrorOccured);
if (BS_SDK_SUCCESS != sdkResult)
{
TRACE("BS2_SetSSLHandler call failed: %d", sdkResult);
return sdkResult;
}
sdkResult = BS2_SetDeviceSSLEventListener(context_, BS2Context::OnSendRootCA);
if (BS_SDK_SUCCESS != sdkResult)
{
TRACE("BS2_SetDeviceSSLEventListener call failed: %d", sdkResult);
}
return sdkResult;
}
C#
if (Util.IsYes())
{
private API.PreferMethod cbPreferMethod = null;
private API.GetRootCaFilePath cbGetRootCaFilePath = null;
private API.GetServerCaFilePath cbGetServerCaFilePath = null;
private API.GetServerPrivateKeyFilePath cbGetServerPrivateKeyFilePath = null;
private API.GetPassword cbGetPassword = null;
private API.OnErrorOccured cbOnErrorOccured = null;
cbPreferMethod = new API.PreferMethod(PreferMethodHandle);
cbGetRootCaFilePath = new API.GetRootCaFilePath(GetRootCaFilePathHandle);
cbGetServerCaFilePath = new API.GetServerCaFilePath(GetServerCaFilePathHandle);
cbGetServerPrivateKeyFilePath = new API.GetServerPrivateKeyFilePath(GetServerPrivateKeyFilePathHandle);
cbGetPassword = new API.GetPassword(GetPasswordHandle);
cbOnErrorOccured = new API.OnErrorOccured(OnErrorOccuredHandle);
//ServicePointManager.SecurityProtocol = (SecurityProtocolType)SecurityProtocolType.Ssl3;
BS2ErrorCode sdkResult = (BS2ErrorCode)API.BS2_SetSSLHandler(sdkContext, cbPreferMethod, cbGetRootCaFilePath, cbGetServerCaFilePath, cbGetServerPrivateKeyFilePath, cbGetPassword, null);
if (sdkResult != BS2ErrorCode.BS_SDK_SUCCESS)
{
Console.WriteLine("BS2_SetSSLHandler failed with : {0}", sdkResult);
API.BS2_ReleaseContext(sdkContext);
sdkContext = IntPtr.Zero;
return;
}
else
{
//bSsl = true;
}
}