问题描述
在我的开发环境中,我在本地有一个 wordpress/woocommerce 站点,所有站点都托管在 IIS 下。
使用下面的代码restsharp可以工作:
var fullEndPoint = string.Concat(site,"/wp-json/wc/v3/",endpoint)
var client = new RestSharp.RestClient(fullEndPoint)
{
Authenticator = OAuth1Authenticator.ForProtectedResource(consumerkey,woosecret,"","")
};
var request = new RestRequest(Method.POST);
request.AddHeader("Content-Type","application/json");
request.AddJsonBody(serializedData);
client.Execute(request);
当我将 fullEndPoint、consumerkey 和 woosecret 更改为反映我们实时站点(在 apache/linux 上运行)的主要测试站点时,我收到
抱歉,您不能创建资源。
如果我使用邮递员将相同的数据发布到我们的测试站点,它会通过并起作用。
为了测试的目的,如果我将客户端的上述声明更改为:
var client = new RestClient("https://wordpress.mytestsite.com/wp-json/wc/v3/products?oauth_consumer_key=ck_a24ad9ddea2d9fe71d9172c415fd51b4dc83a6dc&oauth_signature_method=HMAC-SHA1&oauth_timestamp=1627038994&oauth_nonce=T9gfeZGdmNx&oauth_version=1.0&oauth_signature=OJB1TBpLpA%2Bet0A%2FDFbozOT9nf8%3D");
其中 fullendpoint 是邮递员代码窗口中显示的 Restsharp 代码,代码再次起作用,所以我知道错误具有误导性。那么为什么当我指向我的测试站点时,restsharp 不能以最初的方式为我工作?
编辑:
如果我更改客户端,现在将其设置为:
var client = new RestSharp.RestClient(fullEndPoint)
{
Authenticator = OAuth1Authenticator.ForClientAuthentication(consumerkey,username,password)
};
如果用户名和密码等于用户在 woo commerce 中针对读取/写入访问的消费者密钥设置的用户名,我仍然收到拒绝访问错误
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)