标签: servicestack

为什么不需要使用ServiceStack Json Serializer从json字符串反序列化的对象的构造函数

我想知道为什么不需要构造函数将json字符串反序列化为.Net / C#类对象实例。令我惊讶的是,根本没有调用构造函数并将其删除,并且反序列化器仍从json字符串创建了一个对象实例。这正常吗?

(我使用ServiceStack的json序列化器)

c# serialization constructor servicestack servicestack-text

0
推荐指数
1
解决办法
1237
查看次数

servicestack 在 uri 中传递正斜杠

我正在使用 servicestack 构建一个 Web API,通过网络提供一些旧数据。不幸的是,数据模式并不特别适合 ServiceStack.Ormlite 的标准使用。例如,没有主键,并且在一个表上(非唯一)键实际上可以包含任何字符。在我的示例数据库中,键内有“/”字符。

因此,当使用此路由“/api/objects/{objectCode}”从 Web api 请求资源时,如果所需的 objectCode 为 1/1,则路由应为“/api/objects/1/1”,但这会生成一个页面未发现异常。当我在以下路由“/api/objects/{objectCode}/subObjects”上请求资源时该怎么办

  1. 有谁知道我应该如何解决这个问题?我应该围绕这个问题进行设计还是我可以做些什么来允许它发生?

  2. 另外,理想情况下,我希望能够传递这些 objectCode 的数组,但我不能保证,objectCode 值中不会有 a ,因此分隔字符会出现在资源代码中,从而出现在 ServiceStack 的分隔符解析中,不是吗?

我已经搜索过线索,但只发现人们询问查询字符串中的编码而不是 URI 本身。

uri escaping servicestack

0
推荐指数
1
解决办法
893
查看次数

使用ServiceStack构建一个简单的代理服务器需要什么?

我想知道在/使用ServiceStack构建代理服务是多么困难.考虑到ServiceStack与Redis /序列化等的速度有多快,以及一般实现堆栈的简单程度,这看起来非常诱人.有人试过这个吗?这有多难?

servicestack

0
推荐指数
1
解决办法
620
查看次数

在新标签页中打开PDF

我需要使用servicestack在新窗口中打开PDF.我有一个PDF的MemoryStream,能够将PDF下载到浏览器.我的问题是我无法想出如何在新标签中打开PDF.我已经使用此代码从服务堆栈下载pdf.

public class PDfResult : IDisposable, IStreamWriter, IHasOptions
{
    private readonly Stream _responsestream = null;
    public IDictionary<string, string> Options { get; set; }

    public PDfResult(Stream responseStream)
    {
        _responsestream = responseStream;
        Options = new Dictionary<string, string>
        {
            {"Content-Type", "application/pdf"},
            {"Content-Disposition", "attachment; filename=\"mypdf.pdf\";"}
        };
    }

    public void WriteTo(Stream responseStream)
    {
        if (_responsestream == null)
            return;

        _responsestream.WriteTo(responseStream);
        responseStream.Flush();
    }

    public void Dispose()
    {
        _responsestream.Dispose();
    }
}
Run Code Online (Sandbox Code Playgroud)

这是我使用的锚标签:

<a class="btn" href="api/myapi?rosType=blank&amp;rId=0&amp;rType=Daily&amp;Pages=1&amp;Weeks=1" target="_blank">Generate PDF</a>
Run Code Online (Sandbox Code Playgroud)

c# google-chrome servicestack angularjs internet-explorer-11

0
推荐指数
1
解决办法
1600
查看次数

如何在ServiceStack.OrmLite中使用参数执行SQL语句?

我想在ServiceStack ormlite中使用paraemeters执行SQL语句

String.Format("SELECT OBJECT_ID(@name)", name);
Run Code Online (Sandbox Code Playgroud)

我想要最好的方式.

c# servicestack ormlite-servicestack

0
推荐指数
1
解决办法
3386
查看次数

使用ServiceStack和微服务架构 - 共享安全问题等......

我正在寻找使用ServiceStack并实现基于Martin Fowlers微服务架构的服务,这些服务将部署为Azure中的工作者角色.

也就是说我有10个服务,每个服务都是一个单独的ServiceStack实例,它运行在它自己的Worker Role实例中.

在线的所有示例都显示了ServiceStack的一个实例,它承载了多个服务,这非常有效,但这不符合我要求调查的架构.

什么是使用多个微服务(ServiceStack实例/工作者角色)和验证用户/将某种形式的TokenID传递给其他ServiceStack实例的最佳/首选方法(只有一个将处理登录).

STS会处理这个或像Thinktecture这样的东西吗?此外,ServiceStack是否意味着以这种方式配置?有更简单的选择吗?

实际上,我希望在自己的进程中运行的所有独立服务都能使用单一身份验证服务并共享安全机制.

我将非常感谢在真正的微服务架构中使用ServiceStack的人们的任何反馈.

谢谢约翰

servicestack

0
推荐指数
1
解决办法
1474
查看次数

如何从 ServiceStack ORMLite 检索数据注释别名(“表名”)和别名(“字段名”)?

我需要从此类“tblAccounts”和“AccountNumber”的数据注释中返回别名。它使用 ServiceStack ORM Lite。

[Alias("tblAccounts")]
    [Schema("task")]
    public class Account : IHasId<int>
    {
        [Alias("AccountNumber")]
        public int Id { get; set; }
        [Required]
        public int UnitId { get; set; }
        [Required]
        public int OldAccountNumber { get; set; }
        [Required]
    }
Run Code Online (Sandbox Code Playgroud)

c# data-annotations servicestack ormlite-servicestack

0
推荐指数
1
解决办法
2160
查看次数

ServiceStack:清理字符串值的任何简单方法或选项?

我想知道反序列化时传入的 DTO 中的字符串值是否有任何选项可以“修剪”和“如果为空则设置为空”?我有很多字符串属性需要执行此操作,因此在每个属性的过滤器中手动执行此操作似乎太乏味了...

c# dto servicestack servicestack-text

-2
推荐指数
1
解决办法
346
查看次数

如何将带有 ORMlite 的 byte[] 数组插入到图像列中

我的网络服务的一个子任务是在数据库中保存文件(以及一些元数据)。
Web服务基于ServiceStack及其ORMlite版本。

所以我创建了一个代表数据库中附件的小类:

public class Attachment {
    public string Description { get; set; }
    public string FileName { get; set; }
    public string Type { get; set; }
    public byte[] Data { get; set; }
}
Run Code Online (Sandbox Code Playgroud)

这是实际文件

MemoryStream ms = new MemoryStream(webclient.DownloadData(...));
byte[] data = new byte[...];
ms.Read(data, 0, data.Length);

Attachment file = new Attachment() {
    /* all the other stuff */
    Data = data
};
Run Code Online (Sandbox Code Playgroud)

直到现在都没有问题... :)

现在我拥有了将这个文件放入数据库所需的一切。所以让我们开始吧......

dbCmd.Insert<Attachment>(file);
Run Code Online (Sandbox Code Playgroud)


还有问题...

SqlException: "Operand type …
Run Code Online (Sandbox Code Playgroud)

c# sql-server servicestack ormlite-servicestack

-7
推荐指数
1
解决办法
3083
查看次数