asmx不会返回JSON

时间:2013-09-04 14:45:12

标签: json vb.net asmx

我已经完全重写了这个旧的asmx服务函数,但我还是无法让它返回JSON。它返回XML,即使我使用ajax()并将数据类型和contenttype设置为json。我正在尝试将此函数与Jquery dataTables一起使用。我知道有很多像这样的问题,但我发现它们都是C#而且我无法适应它们。

完整asmx文件的最新pastebin http://pastebin.com/swXKqgd4

新代码

   <WebMethod()> _
    <WebGet(ResponseFormat:=WebMessageFormat.Json)> _
    Public Function rptPendingServerRequests() As Generic.List(Of request)
        Dim _conn As SqlConnection = New SqlConnection(connectionString)
        Dim _dr As SqlDataReader
        Dim Sql As String = String.Empty
        Sql += "<My query here>"

        Try
            Dim _cmd As SqlCommand = New SqlCommand(Sql, _conn)
            _conn.Open()
            _dr = _cmd.ExecuteReader(CommandBehavior.CloseConnection)

            If _dr.HasRows Then
                Dim s As request
                Dim c As New Generic.List(Of request)
                While _dr.Read
                    s = New request
                    With s
                        .requestID = _dr("request_id")
                        .status = _dr("status")
                        .requester = _dr("req_by_user_id")
                        .assignee = _dr("user_id")
                        .nextAction = _dr("description")
                    End With
                    c.Add(s)
                End While

                Return c
            End If

        Catch ex As Exception
            MsgBox(ex.Message)
        Finally
            _conn.Close()
        End Try

    End Function

新课程

<Serializable()> _
Public Class request
    Private _requestID As Integer
    Public Property requestID() As Integer
        Get
            Return _requestID
        End Get
        Set(ByVal value As Integer)
            _requestID = value
        End Set
    End Property

    Private _requester As String
    Public Property requester() As String
        Get
            Return _requester
        End Get
        Set(ByVal value As String)
            _requester = value
        End Set
    End Property

    Private _requestDate As Date
    Public Property requestDate() As Date
        Get
            Return _requestDate
        End Get
        Set(ByVal value As Date)
            _requestDate = value
        End Set
    End Property

    Private _status As Integer
    Public Property status() As Integer
        Get
            Return _status
        End Get
        Set(ByVal value As Integer)
            _status = value
        End Set
    End Property

    Private _assignee As String
    Public Property assignee() As String
        Get
            Return _assignee
        End Get
        Set(ByVal value As String)
            _assignee = value
        End Set
    End Property

    Private _nextAction As String
    Public Property nextAction() As String
        Get
            Return _nextAction
        End Get
        Set(ByVal value As String)
            _nextAction = value
        End Set
    End Property


End Class

原始代码

<WebMethod()> _
<WebGet(ResponseFormat:=WebMessageFormat.Json)> _
Public Function rptPendingServerRequestsOld() As DataSet
    Dim connection As SqlConnection
    Dim command As SqlCommand
    Dim adapter As New SqlDataAdapter
    Dim ds As New DataSet
    Dim sql As String
    sql = ""
    sql += "<MY query here>"

    connection = New SqlConnection(connectionString)

    Try
        connection.Open()
        command = New SqlCommand(sql, connection)
        adapter.SelectCommand = command
        adapter.Fill(ds)
        adapter.Dispose()
        command.Dispose()
        connection.Close()
        Return ds

    Catch ex As Exception
    End Try
End Function

客户端

        $('#report').dataTable({
            "bProcessing": true,
            "sAjaxSource": 'reportdata.asmx/rptPendingServerRequests'
        });

2 个答案:

答案 0 :(得分:0)

因为您从JS而不是

调用此方法
<WebGet(ResponseFormat:=WebMessageFormat.Json)>

使用

<ScriptMethod(ResponseFormat:=ResponseFormat.Json)> 

属性。另外,不要忘记使用

标记WebService类
<ScriptService()> 

属性。

答案 1 :(得分:0)

更改此行。

Public Function rptPendingServerRequests() As Generic.List(Of request)

Public Function rptPendingServerRequests() As String.