Linq to SQl 部分类未跨 Web 服务传递
我使用 linq to SQL 作为 ORM,然后通过 Web 服务将 linq To Sql 对象传递到我的 aspx UI 页面。
当我直接传递 Linq to sql 对象时,这一切工作正常,它们被序列化,并且我能够以 json 的形式访问它们。当我传递 poco DTO 时,这个 Web 服务也可以正常工作,因为这些对象中的一些数据来自几个不同的 linq to SQL 类。
我遇到的问题是当我尝试使用 linq to SQL 类以及自定义分部类中定义的额外字段时。部分类的自定义端中的字段不会通过 Web 服务,部分类的 linq to sql 生成端中的字段确实会遇到。
当我创建对象时,这些字段就在那里,我可以在 Visual Studio 调试器中看到它们,直到它们穿过服务,但它们不在另一端的 json 中。
这是部分类
using System.Runtime.Serialization;
namespace GPSO.ATOMWebDataLayer.LinqToSql
{
public partial class Geofence
{
public string FillColor { get; set; }
}
}
这是 Web 服务
using System;
using System.Collections.Generic;
using System.Configuration;
using System.Data;
using System.Data.SqlClient;
using System.Diagnostics;
using System.Linq;
using System.Net;
using System.ServiceModel;
using System.ServiceModel.Activation;
using System.ServiceModel.Web;
using System.Text;
using System.Web;
using System.Web.Profile;
using System.Web.Security;
using System.Xml;
using GPSO.ATOMWebBusinessLayer;
using GPSO.ATOMWebDataLayer;
using GPSO.ATOMWebDataLayer.LinqToSql;
using GPSO.ATOMWebDataLayer.Objects;
using GPSOnline.ReportWebService;
using Contact = GPSO.ATOMWebDataLayer.LinqToSql.Contact;
using Event = GPSO.ATOMWebBusinessLayer.Event;
using Geofence = GPSO.ATOMWebBusinessLayer.Geofence;
namespace GPSOnline
{
[ServiceContract(Namespace = "GPSOnline")]
[ServiceBehavior(IncludeExceptionDetailInFaults = true)]
[AspNetCompatibilityRequirements(RequirementsMode = AspNetCompatibilityRequirementsMode.Allowed)]
public class ATOMWebService
{
private string _atomDbConnectionString;
private string _aspNetDbConnectionString;
private string _satelliteDbConnectionString;
[OperationContract]
[WebGet]
public IEnumerable<GPSO.ATOMWebDataLayer.LinqToSql.Geofence> GetAllGeofences()
{
NoCache();
var geofenceRepo = new GeofenceRepository(GetConnectionString());
return geofenceRepo.GetAllGeofences().ToList();
}
}
}
and here is the Repository
using System;
using System.Collections.Generic;
using System.Data;
using System.Data.SqlClient;
using System.Linq;
using GPSO.ATOMWebBusinessLayer;
using GPSO.ATOMWebDataLayer.LinqToSql;
using GPSO.MapUtilities;
using GPSO.Repository;
using Microsoft.SqlServer.Types;
using Geofence = GPSO.ATOMWebBusinessLayer.Geofence;
namespace GPSO.ATOMWebDataLayer
{
public class GeofenceRepository
{
private static string _connectionString = "";
public GeofenceRepository(string connectionString)
{
_connectionString = connectionString;
}
public IEnumerable<LinqToSql.Geofence> GetAllGeofences()
{
var dataContext = new AtomWebDataContext(_connectionString);
return allGeofences = dataContext.Geofences.ToList();
}
}
,这是 ui 页面
<%@ Page Language="C#" MasterPageFile="~/Private/ATOMWEB.master" AutoEventWireup="true"
Async="true" Inherits="GPSOnline.Assets" Title="ATOM®web Asset Map" CodeBehind="Assets.aspx.cs" %>
<%@ Register Assembly="Telerik.Web.UI" Namespace="Telerik.Web.UI" TagPrefix="telerik" %>
<%@ Register Src="../UserControls/ucAssetPicker_ClientEvent.ascx" TagName="ucAssetPicker"
TagPrefix="uc1" %>
<asp:Content ID="Content2" ContentPlaceHolderID="ContentPlaceHolderLeft" runat="Server">
<asp:ScriptManagerProxy ID="ScriptManagerProxy" runat="server">
<Services>
<asp:ServiceReference Path="/ATOMWEBService.svc" />
</Services>
<Scripts>
<asp:ScriptReference Path="http://maps.google.com/maps?file=api&v=2&sensor=true&client=gme-gpsonline" />
<asp:ScriptReference Path="~/scripts/MapPanel.js" />
<asp:ScriptReference Path="~/scripts/jquery-1.3.2.min.js" />
<asp:ScriptReference Path="~/scripts/AssetLabel.js" />
<asp:ScriptReference Path="~/scripts/NumberFormatting.js" />
<asp:ScriptReference Path="~/scripts/DateFormatting.js" />
<asp:ScriptReference Path="~/scripts/Utilities.js" />
<asp:ScriptReference Path="~/scripts/geofences.js" />
<asp:ScriptReference Path="~/scripts/mapUtilities.js" />
</Scripts>
</asp:ScriptManagerProxy>
<script type="text/javascript">
var map = null,
atomWebServiceProxy = null,
selectedAssetId = null,
userPreferences = null,
userId = null,
assets = [],
assetMarkers = [],
updatedAssets = [],
assetStatusPanel = null,
assetContextItem = null,
trackAsset = false,
firstTime = true,
deviceChannels = { },
assetPanelLayouts = { },
geoFences = { };
function contentPageLoad() {
atomWebServiceProxy = new GPSOnline.ATOMWebService();
}
/// <summary>
/// <summary>
/// calls the webservice to get all the geo fences.
/// Runs gotGeoFences when service call successfull
/// </summary>
function getGeofences() {
atomWebServiceProxy.GetAllGeofences(gotGeofences);
}
/// <summary>
/// Add the collection of geoFences to the page
/// </summary>
/// <param name="Result"> A collection of GeoFences </param>
function gotGeofences(result) {
geoFences = new GeoFencesObj(map, result, "chkToggleGeofences", "<%=RadContextMenuGotoGeofence.ClientID%>", !userPreferences.DefaultShowGeofences);
if (userPreferences.DefaultLocationType == 2 && userPreferences.HomeSiteId != null) {
geoFences.zoomToGeofence(userPreferences.HomeSiteId);
}
}
}
I am using linq to SQL as my ORM and then passing linq To Sql objects across a web service to my aspx UI pages.
This has been working fine when I pass straight up Linq to sql objects across, they get serialised and I am able access them as json. And This webservice also work fine when I pass over poco DTO, as some of the data in these objects come from a few different linq to SQL classes.
The problem I have is when I try and use linq to SQL class with extra fields defined in a custom partial class. The fields in my custom side of the partial class do not get across the web service, The fields in the linq to sql generated side of the partial class do come across.
The fields are there when I create the object and I can see them in the visual studio debugger up until they go across the service, but they are not in the json on the other side.
Here is the partial class
using System.Runtime.Serialization;
namespace GPSO.ATOMWebDataLayer.LinqToSql
{
public partial class Geofence
{
public string FillColor { get; set; }
}
}
Here is the web service
using System;
using System.Collections.Generic;
using System.Configuration;
using System.Data;
using System.Data.SqlClient;
using System.Diagnostics;
using System.Linq;
using System.Net;
using System.ServiceModel;
using System.ServiceModel.Activation;
using System.ServiceModel.Web;
using System.Text;
using System.Web;
using System.Web.Profile;
using System.Web.Security;
using System.Xml;
using GPSO.ATOMWebBusinessLayer;
using GPSO.ATOMWebDataLayer;
using GPSO.ATOMWebDataLayer.LinqToSql;
using GPSO.ATOMWebDataLayer.Objects;
using GPSOnline.ReportWebService;
using Contact = GPSO.ATOMWebDataLayer.LinqToSql.Contact;
using Event = GPSO.ATOMWebBusinessLayer.Event;
using Geofence = GPSO.ATOMWebBusinessLayer.Geofence;
namespace GPSOnline
{
[ServiceContract(Namespace = "GPSOnline")]
[ServiceBehavior(IncludeExceptionDetailInFaults = true)]
[AspNetCompatibilityRequirements(RequirementsMode = AspNetCompatibilityRequirementsMode.Allowed)]
public class ATOMWebService
{
private string _atomDbConnectionString;
private string _aspNetDbConnectionString;
private string _satelliteDbConnectionString;
[OperationContract]
[WebGet]
public IEnumerable<GPSO.ATOMWebDataLayer.LinqToSql.Geofence> GetAllGeofences()
{
NoCache();
var geofenceRepo = new GeofenceRepository(GetConnectionString());
return geofenceRepo.GetAllGeofences().ToList();
}
}
}
and here is the Repository
using System;
using System.Collections.Generic;
using System.Data;
using System.Data.SqlClient;
using System.Linq;
using GPSO.ATOMWebBusinessLayer;
using GPSO.ATOMWebDataLayer.LinqToSql;
using GPSO.MapUtilities;
using GPSO.Repository;
using Microsoft.SqlServer.Types;
using Geofence = GPSO.ATOMWebBusinessLayer.Geofence;
namespace GPSO.ATOMWebDataLayer
{
public class GeofenceRepository
{
private static string _connectionString = "";
public GeofenceRepository(string connectionString)
{
_connectionString = connectionString;
}
public IEnumerable<LinqToSql.Geofence> GetAllGeofences()
{
var dataContext = new AtomWebDataContext(_connectionString);
return allGeofences = dataContext.Geofences.ToList();
}
}
and here is the ui Page
<%@ Page Language="C#" MasterPageFile="~/Private/ATOMWEB.master" AutoEventWireup="true"
Async="true" Inherits="GPSOnline.Assets" Title="ATOM®web Asset Map" CodeBehind="Assets.aspx.cs" %>
<%@ Register Assembly="Telerik.Web.UI" Namespace="Telerik.Web.UI" TagPrefix="telerik" %>
<%@ Register Src="../UserControls/ucAssetPicker_ClientEvent.ascx" TagName="ucAssetPicker"
TagPrefix="uc1" %>
<asp:Content ID="Content2" ContentPlaceHolderID="ContentPlaceHolderLeft" runat="Server">
<asp:ScriptManagerProxy ID="ScriptManagerProxy" runat="server">
<Services>
<asp:ServiceReference Path="/ATOMWEBService.svc" />
</Services>
<Scripts>
<asp:ScriptReference Path="http://maps.google.com/maps?file=api&v=2&sensor=true&client=gme-gpsonline" />
<asp:ScriptReference Path="~/scripts/MapPanel.js" />
<asp:ScriptReference Path="~/scripts/jquery-1.3.2.min.js" />
<asp:ScriptReference Path="~/scripts/AssetLabel.js" />
<asp:ScriptReference Path="~/scripts/NumberFormatting.js" />
<asp:ScriptReference Path="~/scripts/DateFormatting.js" />
<asp:ScriptReference Path="~/scripts/Utilities.js" />
<asp:ScriptReference Path="~/scripts/geofences.js" />
<asp:ScriptReference Path="~/scripts/mapUtilities.js" />
</Scripts>
</asp:ScriptManagerProxy>
<script type="text/javascript">
var map = null,
atomWebServiceProxy = null,
selectedAssetId = null,
userPreferences = null,
userId = null,
assets = [],
assetMarkers = [],
updatedAssets = [],
assetStatusPanel = null,
assetContextItem = null,
trackAsset = false,
firstTime = true,
deviceChannels = { },
assetPanelLayouts = { },
geoFences = { };
function contentPageLoad() {
atomWebServiceProxy = new GPSOnline.ATOMWebService();
}
/// <summary>
/// <summary>
/// calls the webservice to get all the geo fences.
/// Runs gotGeoFences when service call successfull
/// </summary>
function getGeofences() {
atomWebServiceProxy.GetAllGeofences(gotGeofences);
}
/// <summary>
/// Add the collection of geoFences to the page
/// </summary>
/// <param name="Result"> A collection of GeoFences </param>
function gotGeofences(result) {
geoFences = new GeoFencesObj(map, result, "chkToggleGeofences", "<%=RadContextMenuGotoGeofence.ClientID%>", !userPreferences.DefaultShowGeofences);
if (userPreferences.DefaultLocationType == 2 && userPreferences.HomeSiteId != null) {
geoFences.zoomToGeofence(userPreferences.HomeSiteId);
}
}
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
您需要使用
[DataMemberAttribute]
:You need to use the
[DataMemberAttribute]
: