我几乎复制并粘贴了API PDF中的代码,但我在网上得到了一个Null引用异常:
AccountArray(0) = AccountToUpdate
任何人都知道我做错了什么?谢谢!
Dim boolQueryFinished = False
Dim strCurrentID As String = "0"
Dim contractid As Integer
Dim strWebURI As String = "https://webservices.autotask.net/atservices/1.5/atws.asmx"
Dim myService As New ATWS
myService.Url = strWebURI
Dim cred As New System.Net.NetworkCredential("U", "P")
Dim credCache As New System.Net.CredentialCache
credCache.Add(New Uri(myService.Url), "Basic", cred)
myService.Credentials = credCache
Dim AccountID As New ArrayList
Dim i As Integer
While Not (boolQueryFinished)
Dim strQuery As String = "<queryxml><entity>Contract</entity>" & _
"<query><condition><field>id<expression op=""greaterthan"">" & strCurrentID &
"</expression></field></condition></query>" & _
"</queryxml>"
Dim r As ATWSResponse
r = myService.query(strQuery)
If r.EntityResults.Length > 0 Then
For Each ent As Entity In r.EntityResults
strCurrentID = ent.id
AccountID.Add(CType(ent, Contract).AccountID)
Next
Else
boolQueryFinished = True
While i < ContractName.Count
listOutput.Items.Add(ContractName(i))
listOutput.Items.Add(id(i))
If ContractName(i).Contains("Georges") Then
listOutput.Items.Add("Found it")
Dim sResponse As ATWSResponse
Dim AccountToUpdate As New Contract
Dim AccountArray(0) As Contract
AccountToUpdate.AccountID = AccountID(i)
AccountArray(0) = AccountToUpdate
Dim entityArray() As Entity = CType(AccountArray, Entity())
sResponse = myService.update(entityArray)
If sResponse.ReturnCode = 1 Then
listOutput.Items.Add("Updated")
Else
listOutput.Items.Add("Failed")
End If
End If
i = i + 1
End While
listOutput.Items.Add(id.Count)
listOutput.Items.Add(ContractName.Count)
End If
End While
答案 0 :(得分:0)
看来:
r.EntityResults.Length
不大于零。你已陷入else
条款。While i < ContractName.Count
循环(但不清楚此ContractName
是什么。i
尚未初始化,因此其价值为0
。ArgumentOutOfRange Exception
,因为我们正试图获取空ArrayList的索引0。
AccountToUpdate.AccountID = AccountID(i)
您确定要在While
区块内设置Else
循环吗?我很好奇End If
陈述在哪里?