主頁 > 軟體工程 > VB呼叫Java開發的webservice介面問題

VB呼叫Java開發的webservice介面問題

2020-09-19 10:50:19 軟體工程

我有一個java的webservice介面程式,有2個方法,在VB環境上呼叫這個介面,以前一直好使,最近不知道為什么,在呼叫介面時出現這樣的問題,方法1 在應用程式中一直都好使,但方法2不好使,webService方法沒有調整過。我在程式登陸時進行了soapClient.MSSoapInit 操作,方法1正常呼叫,但方法2就不能呼叫,提示沒有方法2,必須再重新soapClient.MSSoapInit 后就可以呼叫方法2 了,原來是不需要重新soapClient.MSSoapInit 的,是什么原因?大俠們幫解決一下呀,急死我了!!!

uj5u.com熱心網友回復:

代碼功能歸根結底不是別人幫自己看或講解或注釋出來的;而是被自己靜下心來花足夠長的時間和精力親自動手單步或設斷點或對執行到某步獲得的中間結果顯示或寫到日志檔案中一步一步分析出來的。
提醒:再牛×的老師也無法代替學生自己領悟和上廁所!
單步除錯和設斷點除錯是程式員必須掌握的技能之一。

uj5u.com熱心網友回復:

謝謝老師,我單步除錯執行到呼叫方法地方,

uj5u.com熱心網友回復:

 '  Set cLnt = New SoapClient30
'    Call cLnt.MSSoapInit(strSvc & "WSImpAndExpWeighInfoFacade?WSDL") '加上此行就可以執行下面的方法
 '   cLnt.ConnectorProperty("Timeout") = "90000"
    result = cLnt.importWeighInfo(weighString) '執行到此處提示無這個方法,

uj5u.com熱心網友回復:

Set cLnt = New SoapClient30
這行怎么可以注釋掉呢?

uj5u.com熱心網友回復:

我發貼時注釋了,錯了,下面是我程式的源代碼,result = cLnt.importWeighInfo(Info)   '這個位置不出現問題。謝謝老師,幫我分析一下,程式一直都在運行,突然出現這個問題,沒有做過任何改動。Java的webService沒有修改,本地程式也沒有修改,就是突然出現問題,客戶端不能呼叫方法了,其他代碼地方使用webService均正常。
Private Sub Button2_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button2.Click
        Dim Info As String = ""
        Dim baund As String
        Dim tile As String = ""
        If t_TrainNum1.Text = "" Then
            MsgBox("車號不能為空!", 64, "溫馨提示")
            Exit Sub
        End If
        'BandNo
        If BandNo.Text = "" Then
            MsgBox("磅單號不能為空!", 64, "溫馨提示")
            Exit Sub
        End If
        If CrossBand.Text = "請選擇毛重衡器" Then
            MsgBox("毛重衡器不能為空!", 64, "提示")
            Exit Sub
        End If
        If TareBand.Text = "請選擇皮重衡器" Then
            MsgBox("皮重衡器不能為空!", 64, "提示")
            Exit Sub
        End If
        If CrossOpreator.Text = "請選擇" Then
            MsgBox("請選擇毛重司磅員!", 64, "提示")
            Exit Sub
        End If
        If TareOpreator.Text = "請選擇" Then
            MsgBox("請選擇皮重司磅員!", 64, "提示")
            Exit Sub
        End If
        If t_Gross.Text = 0 Then
            MsgBox("毛重不能為零!", 64, "提示")
            Exit Sub
        End If
        If t_Tare.Text = 0 Then
            MsgBox("皮重不能為零!", 64, "提示")
            Exit Sub
        End If
        If Trim(t_Demo.Text) = "" Then
            MsgBox("手工錄入原因不能為空!", 64, "提示")
            Exit Sub
        End If
        Try
            Select Case CrossBand.Text
                Case "一號汽車衡"
                    tile = "Q1"
                Case "二號汽車衡"
                    tile = "Q2"
                Case "三號汽車衡"
                    tile = "Q3"
                Case "四號汽車衡"
                    tile = "Q4"
                Case "五號汽車衡"
                    tile = "Q5"
                Case "六號汽車衡"
                    tile = "Q6"
                Case "七號汽車衡"
                    tile = "Q7"
                Case "八號汽車衡"
                    tile = "Q8"
                Case "九號汽車衡"
                    tile = "Q9"
                Case "十號汽車衡"
                    tile = "QA"
                Case "十一號汽車衡"
                    tile = "QB"
                Case "十二號汽車衡"
                    tile = "QC"
                Case "十三號汽車衡"
                    tile = "QD"
                Case "十四號汽車衡"
                    tile = "QE"
                Case "十五號汽車衡"
                    tile = "QF"
                Case "一號軌道衡"
                    tile = "G1"
                Case "二號軌道衡"
                    tile = "G2"
                Case "三號軌道衡"
                    tile = "G3"
                Case "四號軌道衡"
                    tile = "G4"
                Case "五號軌道衡"
                    tile = "G5"
                Case "六號軌道衡"
                    tile = "G6"
                Case "七號軌道衡"
                    tile = "G7"
                Case "八號軌道衡"
                    tile = "G8"
                Case "九號軌道衡"
                    tile = "G9"
                Case "十號軌道衡"
                    tile = "GA"
                Case "十一號軌道衡"
                    tile = "GB"
                Case "十二號軌道衡"
                    tile = "GC"
                Case "十三號軌道衡"
                    tile = "GD"
                Case "十四號軌道衡"
                    tile = "GE"
                Case "十五號軌道衡"
                    tile = "GF"

            End Select
            If AutoBaund.Checked = True Then
                baund = GetNewBaundNo(OWeightORG.GetBaundNO)
                BandNo.Text = tile & baund
            End If


            If CrossBand.SelectedIndex = -1 Then CrossBand.SelectedIndex = 0
            If TareBand.SelectedIndex = -1 Then TareBand.SelectedIndex = 0
            If LSSC.Checked = True Then
                'Info = weighNoticeEntryID & Separator & _
                '                   BandNo.Text & Separator & _
                '                   t_TrainNum1.Text & Separator & _
                '                   t_Gross.Text & Separator & _
                '                   Format(CDate(Dt_StartDate.Text), "yyMMddHHmmss") & Separator & _
                '                   t_Tare.Text & Separator & _
                '                   Format(CDate(Dt_EndDate.Text), "yyMMddHHmmss") & Separator & _
                '                   t_Net.Text & Separator & _
                '                   crossCode(CrossBand.SelectedIndex) & Separator & _
                '                   tareCode(TareBand.SelectedIndex) & Separator & _
                '                   Trim(crossOP(CrossOpreator.SelectedIndex)) & Separator & _
                '                   Trim(tareOP(TareOpreator.SelectedIndex)) & Separator & MaterialNumber & Separator & Separator & "01.01" & Separator & _
                '                   Cb_Consignee.Text & Separator & Cb_Consigner.Text & Separator & t_Demo.Text

            Else
                Info = weighNoticeEntryID & Separator & _
                                   BandNo.Text & Separator & _
                                   t_TrainNum1.Text & Separator & _
                                   t_Gross.Text & Separator & _
                                   Format(CDate(Dt_StartDate.Text), "yyMMddHHmmss") & Separator & _
                                   t_Tare.Text & Separator & _
                                   Format(CDate(Dt_EndDate.Text), "yyMMddHHmmss") & Separator & _
                                   t_Net.Text & Separator & _
                                   crossCode(CrossBand.SelectedIndex) & Separator & _
                                   tareCode(TareBand.SelectedIndex) & Separator & _
                                   Trim(crossOP(CrossOpreator.SelectedIndex)) & Separator & _
                                   Trim(tareOP(TareOpreator.SelectedIndex)) & Separator & MaterialNumber & Separator & Separator & "01.01" & Separator & t_Demo.Text & "-此單據為手工錄入" & Separator & t_TrainType.Text

                If MsgBox("      車號: " & t_TrainNum1.Text & vbCrLf & vbCrLf & _
                          "      總重: " & t_Gross.Text & vbCrLf & vbCrLf & _
                          "      自重: " & t_Tare.Text & vbCrLf & vbCrLf & _
                          "      凈重: " & t_Net.Text & vbCrLf & vbCrLf & _
                          "  毛重衡器: " & CrossBand.Text & vbCrLf & vbCrLf & _
                          "  皮重衡器: " & TareBand.Text & vbCrLf & vbCrLf & _
                          "  毛重時間: " & Dt_StartDate.Text & vbCrLf & vbCrLf & _
                          "  皮重時間: " & Dt_EndDate.Text & vbCrLf & vbCrLf & _
                          "  識訓單位: " & Cb_Consigner.Text & vbCrLf & vbCrLf & _
                          "  發貨單位: " & Cb_Consignee.Text & vbCrLf & vbCrLf & _
                          "  物資名稱: " & Cb_Goods.Text & vbCrLf & vbCrLf & _
                          "    磅單號: " & BandNo.Text & vbCrLf & vbCrLf & _
                          "毛重司磅員: " & CrossOpreator.Text & vbCrLf & vbCrLf & _
                          "皮重司磅員: " & TareOpreator.Text, MsgBoxStyle.YesNo, "手工錄入資訊提示") = MsgBoxResult.No Then
                    Exit Sub
                End If

            End If
            Dim result As String
            Dim cLnt As New SoapClient30
            If LSSC.Checked = True Then
                result = cLnt.importWeighInfo2(Info)
            Else
                 'Call cLnt.MSSoapInit(strSvc & "WSImpAndExpWeighInfoFacade?WSDL") 
                result = cLnt.importWeighInfo(Info)   '這個位置不出現問題
            End If
            If Mid(result, 1, 1) = "1" Then
                Dim sqlstring As String = String.Empty
                sqlstring = "Insert into WeightBridge_DB_Weight(磅單號,發貨單位,識訓單位,物資,毛重,皮重,凈重," & _
                            "毛重時間,皮重時間,毛重操作員,皮重操作員,上傳標志,審核次數,列印次數,修改標志,作廢標志" & _
                            ",車號,車型,標重,檢斤次數,二次檢斤順序,毛重衡器,皮重衡器,檢斤型別,流向,檢斤方式,備注,分錄ID,物料編碼) values ('" & _
                            BandNo.Text & "','" & Cb_Consignee.Text & "','" & Cb_Consigner.Text & "','" & Cb_Goods.Text & "'," & t_Gross.Text & "," & t_Tare.Text & "," & _
                            t_Net.Text & ",'" & Dt_StartDate.Text & "','" & Dt_EndDate.Text & "','" & Ob_Op.Op_Name & "','" & Ob_Op.Op_Name & "'," & _
                            1 & "," & 1 & "," & 0 & "," & 0 & "," & 0 & ",'" & _
                            t_TrainNum1.Text & "','" & t_TrainType.Text & "'," & 0 & "," & 2 & ",'" & "" & "','" & CrossBand.Text & "','" & _
                            TareBand.Text & "','" & cb_WeightType.Text & "','" & Cb_ComTo.Text & "','','" & t_Demo.Text & "','" & weighNoticeEntryID & "','" & MaterialNumber & "')"
                SQLDBFactory.ExecuteCommand(sqlstring)
                MaterialNumber = ""
                weighNoticeEntryID = ""
                MsgBox("上傳成功!", 0, "上傳成功")
                Log.Log_Type = "手工錄入"
                Log.Log_StationName = Object_ParSet.Station_Name
                Log.Log_Memo = t_Demo.Text
                Log.Log_DateTime = Now
                Log.Log_BaundNO = BandNo.Text
                Log.Log_OP = Ob_Op.Op_Name
                Log.Insertlog(False)
            Else
                MsgBox("上傳失敗!" & result, 0, "上傳失敗")
            End If
        Catch ex As Exception
            Log.ToLogTxt("[" & Now & "]" & "FrmPersonWeight-Button2_Click:" & ex.Message)
        End Try
    End Sub

uj5u.com熱心網友回復:

            Dim result As String
            Dim cLnt As New SoapClient30
            If LSSC.Checked = True Then
                result = cLnt.importWeighInfo2(Info)
            Else
                 'Call cLnt.MSSoapInit(strSvc & "WSImpAndExpWeighInfoFacade?WSDL")
                result = cLnt.importWeighInfo(Info)   '這個位置不出現問題
            End If
            Set cLnt=Nothing '★★★★★★★★★★
            If Mid(result, 1, 1) = "1" Then

檢查是否資源泄漏的辦法之一:
在任務管理器 行程 查看 選擇列 里面選擇:記憶體使用、虛擬記憶體大小、句柄數、執行緒數、USER物件、GDI物件
讓你的程式(行程)不退出,回圈執行主流程很多遍,越多越好,比如1000000次甚至無限回圈,記錄以上各數值,再隔至少一小時,越長越好,比如一個月,再記錄以上各數值。如果以上兩組數值的差較大或隨時間流逝不斷增加,則鐵定有對應資源的資源泄漏!

轉載請註明出處,本文鏈接:https://www.uj5u.com/gongcheng/80916.html

標籤:網絡編程

上一篇:本人vb新手,請教個問題

下一篇:用VBA正則實作在word中的替換

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • Git本地庫既關聯GitHub又關聯Gitee

    創建代碼倉庫 使用gitee舉例(github和gitee差不多) 1.在gitee右上角點擊+,選擇新建倉庫 ? 2.選擇填寫倉庫資訊,然后進行創建 ? 3.服務端已經準備好了,本地開始作準備 (1)Git 全域設定 git config --global user.name "成鈺" git c ......

    uj5u.com 2020-09-10 05:04:14 more
  • CODING DevOps 代碼質量實戰系列第二課,相約周三

    隨著 ToB(企業服務)的興起和 ToC(消費互聯網)產品進入成熟期,線上故障帶來的損失越來越大,代碼質量越來越重要,而「質量內建」正是 DevOps 核心理念之一。**《DevOps 代碼質量實戰(PHP 版)》**為 CODING DevOps 代碼質量實戰系列的第二課,同時也是本系列的 PHP ......

    uj5u.com 2020-09-10 05:07:43 more
  • 推薦Scrum書籍

    推薦Scrum書籍 直接上干貨,推薦書籍清單如下(推薦有順序的哦) Scrum指南 Scrum精髓 Scrum敏捷軟體開發 Scrum捷徑 硝煙中的Scrum和XP : 我們如何實施Scrum 敏捷軟體開發:Scrum實戰指南 Scrum要素 大規模Scrum:大規模敏捷組織的設計 用戶故事地圖 用 ......

    uj5u.com 2020-09-10 05:07:45 more
  • CODING DevOps 代碼質量實戰系列最后一課,周四發車

    隨著 ToB(企業服務)的興起和 ToC(消費互聯網)產品進入成熟期,線上故障帶來的損失越來越大,代碼質量越來越重要,而「質量內建」正是 DevOps 核心理念之一。 **《DevOps 代碼質量實戰(Java 版)》**為 CODING DevOps 代碼質量實戰系列的最后一課,同時也是本系列的 ......

    uj5u.com 2020-09-10 05:07:52 more
  • 敏捷軟體工程實踐書籍

    Scrum轉型想要做好,第一步先了解并真正落實Scrum,那么我推薦的Scrum書籍是要看懂并實踐的。第二步是團隊的工程實踐要做扎實。 下面推薦工程實踐書單: 重構:改善既有代碼的設計 決議極限編程 : 擁抱變化 代碼整潔代碼 程式員的職業素養 修改代碼的藝術 撰寫可讀代碼的藝術 測驗驅動開發 : ......

    uj5u.com 2020-09-10 05:07:55 more
  • Jenkins+svn+nginx實作windows環境自動部署vue前端專案

    前面文章介紹了Jenkins+svn+tomcat實作自動化部署,現在終于有空抽時間出來寫下Jenkins+svn+nginx實作自動部署vue前端專案。 jenkins的安裝和配置已經在前面文章進行介紹,下面介紹實作vue前端專案需要進行的哪些額外的步驟。 注意:在安裝jenkins和nginx的 ......

    uj5u.com 2020-09-10 05:08:49 more
  • CODING DevOps 微服務專案實戰系列第一課,明天等你

    CODING DevOps 微服務專案實戰系列第一課**《DevOps 微服務專案實戰:DevOps 初體驗》**將由 CODING DevOps 開發工程師 王寬老師 向大家介紹 DevOps 的基本理念,并探討為什么現代開發活動需要 DevOps,同時將以 eShopOnContainers 項 ......

    uj5u.com 2020-09-10 05:09:14 more
  • CODING DevOps 微服務專案實戰系列第二課來啦!

    近年來,工程專案的結構越來越復雜,需要接入合適的持續集成流水線形式,才能滿足更多變的需求,那么如何優雅地使用 CI 能力提升生產效率呢?CODING DevOps 微服務專案實戰系列第二課 《DevOps 微服務專案實戰:CI 進階用法》 將由 CODING DevOps 全堆疊工程師 何晨哲老師 向 ......

    uj5u.com 2020-09-10 05:09:33 more
  • CODING DevOps 微服務專案實戰系列最后一課,周四開講!

    隨著軟體工程越來越復雜化,如何在 Kubernetes 集群進行灰度發布成為了生產部署的”必修課“,而如何實作安全可控、自動化的灰度發布也成為了持續部署重點關注的問題。CODING DevOps 微服務專案實戰系列最后一課:**《DevOps 微服務專案實戰:基于 Nginx-ingress 的自動 ......

    uj5u.com 2020-09-10 05:10:00 more
  • CODING 儀表盤功能正式推出,實作作業資料可視化!

    CODING 儀表盤功能現已正式推出!該功能旨在用一張張統計卡片的形式,統計并展示使用 CODING 中所產生的資料。這意味著無需額外的設定,就可以收集歸納寶貴的作業資料并予之量化分析。這些海量的資料皆會以圖表或串列的方式躍然紙上,方便團隊成員隨時查看各專案的進度、狀態和指標,云端協作迎來真正意義上 ......

    uj5u.com 2020-09-10 05:11:01 more
最新发布
  • windows系統git使用ssh方式和gitee/github進行同步

    使用git來clone專案有兩種方式:HTTPS和SSH:
    HTTPS:不管是誰,拿到url隨便clone,但是在push的時候需要驗證用戶名和密碼;
    SSH:clone的專案你必須是擁有者或者管理員,而且需要在clone前添加SSH Key。SSH 在push的時候,是不需要輸入用戶名的,如果配置... ......

    uj5u.com 2023-04-19 08:41:12 more
  • windows系統git使用ssh方式和gitee/github進行同步

    使用git來clone專案有兩種方式:HTTPS和SSH:
    HTTPS:不管是誰,拿到url隨便clone,但是在push的時候需要驗證用戶名和密碼;
    SSH:clone的專案你必須是擁有者或者管理員,而且需要在clone前添加SSH Key。SSH 在push的時候,是不需要輸入用戶名的,如果配置... ......

    uj5u.com 2023-04-19 08:35:34 more
  • 2023年農牧行業6大CRM系統、5大場景盤點

    在物聯網、大資料、云計算、人工智能、自動化技術等現代資訊技術蓬勃發展與逐步成熟的背景下,數字化正成為農牧行業供給側結構性變革與高質量發展的核心驅動因素。因此,改造和提升傳統農牧業、開拓創新現代智慧農牧業,加快推進農牧業的現代化、資訊化、數字化建設已成為農牧業發展的重要方向。 當下,企業數字化轉型已經 ......

    uj5u.com 2023-04-18 08:05:44 more
  • 2023年農牧行業6大CRM系統、5大場景盤點

    在物聯網、大資料、云計算、人工智能、自動化技術等現代資訊技術蓬勃發展與逐步成熟的背景下,數字化正成為農牧行業供給側結構性變革與高質量發展的核心驅動因素。因此,改造和提升傳統農牧業、開拓創新現代智慧農牧業,加快推進農牧業的現代化、資訊化、數字化建設已成為農牧業發展的重要方向。 當下,企業數字化轉型已經 ......

    uj5u.com 2023-04-18 08:00:18 more
  • 計算機組成原理—存盤器

    計算機組成原理—硬體結構 二、存盤器 1.概述 存盤器是計算機系統中的記憶設備,用來存放程式和資料 1.1存盤器的層次結構 快取-主存層次主要解決CPU和主存速度不匹配的問題,速度接近快取 主存-輔存層次主要解決存盤系統的容量問題,容量接近與價位接近于主存 2.主存盤器 2.1概述 主存與CPU的聯 ......

    uj5u.com 2023-04-17 08:20:31 more
  • 談一談我對協同開發的一些認識

    如今各互聯網公司普通都使用敏捷開發,采用小步快跑的形式來進行專案開發。如果是小專案或者小需求,那一個開發可能就搞定了。但對于電商等復雜的系統,其功能多,結構復雜,一個人肯定是搞不定的,所以都是很多人來共同開發維護。以我曾經待過的商城團隊為例,光是后端開發就有七十多人。 為了更好地開發這類大型系統,往 ......

    uj5u.com 2023-04-17 08:18:55 more
  • 專案管理PRINCE2核心知識點整理

    PRINCE2,即 PRoject IN Controlled Environment(受控環境中的專案)是一種結構化的專案管理方法論,由英國政府內閣商務部(OGC)推出,是英國專案管理標準。
    PRINCE2 作為一種開放的方法論,是一套結構化的專案管理流程,描述了如何以一種邏輯性的、有組織的方法,... ......

    uj5u.com 2023-04-17 08:18:51 more
  • 談一談我對協同開發的一些認識

    如今各互聯網公司普通都使用敏捷開發,采用小步快跑的形式來進行專案開發。如果是小專案或者小需求,那一個開發可能就搞定了。但對于電商等復雜的系統,其功能多,結構復雜,一個人肯定是搞不定的,所以都是很多人來共同開發維護。以我曾經待過的商城團隊為例,光是后端開發就有七十多人。 為了更好地開發這類大型系統,往 ......

    uj5u.com 2023-04-17 08:18:00 more
  • 專案管理PRINCE2核心知識點整理

    PRINCE2,即 PRoject IN Controlled Environment(受控環境中的專案)是一種結構化的專案管理方法論,由英國政府內閣商務部(OGC)推出,是英國專案管理標準。
    PRINCE2 作為一種開放的方法論,是一套結構化的專案管理流程,描述了如何以一種邏輯性的、有組織的方法,... ......

    uj5u.com 2023-04-17 08:17:55 more
  • 計算機組成原理—存盤器

    計算機組成原理—硬體結構 二、存盤器 1.概述 存盤器是計算機系統中的記憶設備,用來存放程式和資料 1.1存盤器的層次結構 快取-主存層次主要解決CPU和主存速度不匹配的問題,速度接近快取 主存-輔存層次主要解決存盤系統的容量問題,容量接近與價位接近于主存 2.主存盤器 2.1概述 主存與CPU的聯 ......

    uj5u.com 2023-04-17 08:12:06 more