ActiveX Control 向Https服务器发送文件

1. 创建ActiveX 插件工程

1)创建CHttpConnection和CHttpFile之前对Url进行解析,判断服务类型

AfxParseURL(strServerPath, dwServiceType, strServerName, strObjectName, nPort);
除了第一个参数,其它均为出口参数,dwServiceType可获得服务类型。
2)创建CInternetSession、CHttpConnection、和打开请求获得CHttpFile。
判断服务类型是否为Https,如果是则需设置新的标记。

DWORD dwFlags = INTERNET_FLAG_DONT_CACHE;
if (AFX_INET_SERVICE_HTTPS == dwServiceType)
{
        dwFlags = INTERNET_FLAG_SECURE |  
	INTERNET_FLAG_EXISTING_CONNECT |  
	INTERNET_FLAG_RELOAD |  
	INTERNET_FLAG_NO_CACHE_WRITE |  
	INTERNET_FLAG_IGNORE_CERT_DATE_INVALID |  
	INTERNET_FLAG_IGNORE_CERT_CN_INVALID;
}
CInternetSession mySession;
CHttpConnection *pHttpConnection = mySession.GetHttpConnection(strServerName, nPort);
CHttpFile *pHttpFile = pHttpConnection->OpenRequest(CHttpConnection::HTTP_VERB_PUT, strObjectName, NULL, 1, NULL, NULL, dwFlags);

获取服务如果服务类型为AFX_INET_SERVICE_HTTPS,则需先获取服务器选项,然后设置标记并设置Web服务器选项。

if (AFX_INET_SERVICE_HTTPS == dwServiceType)
{
	// ignore the certificate
	pHttpFile->QueryOption(INTERNET_OPTION_SECURITY_FLAGS, dwFlags);
	dwFlags |= (SECURITY_FLAG_IGNORE_CERT_CN_INVALID |
		SECURITY_FLAG_IGNORE_CERT_DATE_INVALID |
		SECURITY_FLAG_IGNORE_UNKNOWN_CA  |
		SECURITY_FLAG_IGNORE_WRONG_USAGE |
		SECURITY_FLAG_IGNORE_REVOCATION);
	// set web server option
	pHttpFile->SetOption(INTERNET_OPTION_SECURITY_FLAGS, dwFlags);
	if (UseHttpsSendReqEx(pHttpFile, dwPostSize, strLocalFile))
	{
		// 该函数向Https服务器发送本地文件strLocalFile,使用CHTTPFile::SendRequestEx()函数
	}
}



  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值