2

サーバー側 (ASP.NET/C#) からこのフォームを投稿したい:

<FORM action="https://login:password@payment.architrade.com/cgi-adm/refund.cgi" method=POST>
    <input type="hidden" name="merchant" value="12345678">
    <input type="hidden" name="transact" value="11111111">
    <input type="hidden" name="amount" value="2000">
    <input type="hidden" name="currency" value="208">
    <input type="hidden" name="orderid" value="11223344">
    <input type="hidden" name="md5key" value="cfcd208495d565ef66e7dff9f98764da">
    <input type="hidden" name="textreply" value="yes">
</FORM>

WebClient.UploadValues を使用しようとしています。私のコードは

 private void PostRefundRequest(Mediachase.Commerce.Orders.Payment payment)
    {
        WebClient webClient = new WebClient();
        NameValueCollection refundRequest = new NameValueCollection();
        PaymentMethodDto dibs = PaymentManager.GetPaymentMethodBySystemName("DIBS", SiteContext.Current.LanguageName);
        string merchant = GetParameterByName(dibs, DIBSPaymentGateway.UserParameter).Value;
        PurchaseOrder po = payment.Parent.Parent as PurchaseOrder;
        string orderid = po.TrackingNumber;
        string transact = payment.TransactionID;
        string amount = (payment.Amount * 100).ToString();
        refundRequest.Add("merchant", merchant);
        refundRequest.Add("transact", transact);
        refundRequest.Add("amount", amount );

        refundRequest.Add("currency", payment.Parent.Parent.BillingCurrency);
        refundRequest.Add("orderid", orderid);
        string md5 = GetMD5KeyRefund(merchant, orderid, transact, amount);
        refundRequest.Add("md5key", md5);
        refundRequest.Add("textreply", "yes");
        byte[] responseArray = webClient.UploadValues("https://<mylogin>:<mypassword>@payment.architrade.com/cgi-adm/refund.cgi", refundRequest);
    }

デバッグしようとしましたが、すべて正しいように見えますが、API は HTTP 401 (Unauthorized) を返します。私の懸念は: WebClient.UploadValues は API の URL (ユーザー名/パスワードを含む) をサポートしていますか?

ありがとうございました。

4

2 に答える 2

3

UploadValues のメソッド パラメータに Post を含める必要があります。

NameValueCollection data = new NameValueCollection();
data["input-data1"] = "value1";
data["input-data2"] = "value2";
data["input-data3"] = "value3";

WebClient webClient = new WebClient();
webClient.Credentials = new NetworkCredential(mylogin, mypassword);
byte[] responseBytes = webClient.UploadValues("http://www.example.com/posttome.aspx", "POST", data);
string response = Encoding.UTF8.GetString(responseBytes);

更新: ドキュメントでは POST が http スキームのデフォルトであると記載されているため、これでは不十分かもしれません ( http://msdn.microsoft.com/en-us/library/9w7b4fz7.aspx ) https でも同じであると思います

更新 2: Microsoftは、セキュリティ上の理由からInternet Explorer ( http://support.microsoft.com/kb/834489 ) の URL でその認証を無効にしているため、Web クライアントで無効になっている可能性があります。

于 2012-04-19T11:07:21.480 に答える
-4

フォームにIDを付けて、次のコードを使用して送信するだけです

 $('#formid').submit();
于 2012-04-19T07:52:10.543 に答える