小编Tha*_*kou的帖子

同步IClientMessageInspector和IParameterInspector之间的关联状态

我有一个wcf客户端.根据要求,我需要记录请求中的一些元数据(以及请求中未包含的用户数据.)然后,如果请求成功,我可能必须记录响应元数据并根据标志,完整的肥皂要求.

我正在尝试以正确的方式执行此操作(使用IParameterInspector检查元数据和IClientMessageInspector以获取Soap),但我无法关联两个接口请求.我不确定这里的线程安全性.这是我在哪里的精简版...

     public class SoapRequestInfo
{
    public string UserId { get; set; }
    public Guid Key { get; set; }
    //would contain a lot more info
}

public class OperationProfilerParameterInspector : IParameterInspector, IClientMessageInspector
{
    //before serialization
    public object BeforeCall(string operationName, object[] inputs) //IParameterInspector
    {
        //Add the operation, record some specific inputs to db
        return new SoapRequestInfo
                            {
                                UserId = "1234",
                                Key = new Guid()
                            };
    }

    public void AfterCall(string operationName, object[] outputs, object returnValue, object correlationState) //IParameterInspector
    {
       var info …
Run Code Online (Sandbox Code Playgroud)

wcf

16
推荐指数
1
解决办法
1095
查看次数

如何创建解码器的完整副本?

我正在编写一个视频解码器(使用FFMPEG/AVCodec)来自定义实现mpeg4视频流.这个视频流的特点是它可以分成许多"子"流,根据同一个父节点创建许多P帧.我正在尝试解码的视频流实际上是一种"视频树".像这样的东西:

I <--P <--P <---------------------P <-------------- P <------------ P
           \ <--P <--P <--P        \ <--P <--P       \ <--P <--P 
Run Code Online (Sandbox Code Playgroud)

我已经写了一个基本的解码器,当我决定遵循一条路径时工作正常,问题是当我尝试在视频树中跟随多个路径时.此时我需要"解析"我的解码器以跟随两个不同的视频流.拆分不仅可能发生在关键帧之后,甚至在P帧之后,所以我需要复制AVCodecContext(我使用avcodec_copy_context)但它似乎从干净的状态创建新的解码器..它似乎忽略了以前的视频状态因此,解码的P帧被"应用"到空视频帧.可能复制上下文使用avcodec_copy_context是不够的...任何建议?如何复制上下文和解码器的完整状态?或者,有没有其他方法使用引用解码我的流?谢谢!

ffmpeg mpeg-4 libavcodec avcodec

15
推荐指数
1
解决办法
1825
查看次数

支持多个版本的编译依赖项(vNext)

我参与了一个目前支持MVC 2 - MVC 5的开源库,我也想支持MVC 6(以及更高版本).为了支持每个版本的MVC,我们利用MSBuild 的Condition特性在构建时包含正确版本的MVC及其依赖项(取决于其值DefineConstants).通过使用相同的项目文件和源代码为每个MVC版本创建单独的DLL,可以为所有受支持的MVC版本使用单个项目文件.

<ItemGroup Condition=" $(DefineConstants.Contains('MVC2')) ">
    <Reference Include="System.Web.Mvc, Version=2.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35, processorArchitecture=MSIL" />
</ItemGroup>
<ItemGroup Condition=" $(DefineConstants.Contains('MVC3')) ">
    <!-- Due to the windows update MS14-059, we need this hack to ensure we can build MVC3 both on machines that have the update and those that don't -->
    <Reference Condition=" Exists('$(windir)\Microsoft.NET\assembly\GAC_MSIL\System.Web.Mvc\v4.0_3.0.0.0__31bf3856ad364e35\System.Web.Mvc.dll') " Include="System.Web.Mvc, Version=3.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35, processorArchitecture=MSIL" />
    <Reference Condition=" !Exists('$(windir)\Microsoft.NET\assembly\GAC_MSIL\System.Web.Mvc\v4.0_3.0.0.0__31bf3856ad364e35\System.Web.Mvc.dll') " Include="System.Web.Mvc, Version=3.0.0.1, Culture=neutral, PublicKeyToken=31bf3856ad364e35, processorArchitecture=MSIL">
        <Private>True</Private>
        <HintPath>..\packages\Microsoft.AspNet.Mvc.3.0.20105.1\lib\net40\System.Web.Mvc.dll</HintPath>
    </Reference>
    <Reference Include="System.Web.Razor, …
Run Code Online (Sandbox Code Playgroud)

c# asp.net-mvc roslyn asp.net-core-mvc asp.net-core

15
推荐指数
1
解决办法
569
查看次数

执行File.Delete后,该文件仍处于DELETE PENDING状态

File.Delete有时候调用文件后仍然存在怎么可能?我使用简单的代码来重现问题File.Open.预期的例外是FileNotFoundException.我检查了Process Monitor v3.05中的操作,文件的结果是"DELETE PENDING"并且返回UnauthorizedAccessException.有人有解释吗?

public class Program
{
    private const string DummyFileName = "dummy.txt";

    private static void Main(string[] args)
    {
        int attempt = 0;
        while (true)
        {
            using (File.Create(DummyFileName))
            {
            }

            File.Delete(DummyFileName);

            try
            {
                attempt++;
                using (File.Open(DummyFileName, FileMode.Open, FileAccess.ReadWrite, FileShare.None))
                {
                }
            }
            catch (FileNotFoundException)
            {
            }
            catch (UnauthorizedAccessException ex)
            {
                Console.WriteLine("File exists{0}", File.Exists(DummyFileName));
                Console.WriteLine("File remains in DELETE PENDING state in attempt {0}.", attempt);
                Console.WriteLine(ex);
                Console.ReadKey();
            }
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

c# io

9
推荐指数
1
解决办法
1495
查看次数

重命名表中的所有列,删除空格

我有一个表格,我从一个非常大的CSV导入,有超过100列.我刚刚注意到他们在列名中导入了空格.

有没有办法重命名所有列并删除空格?

mysql

8
推荐指数
1
解决办法
712
查看次数

使用简单更新的计数器列的原子增量

我试图了解如何安全地增加计数器列,这可能会被许多用户同时递增(它是移动应用程序的Web API).

我已经阅读了SO中用于处理该问题的策略的热门问题,但我似乎无法弄清楚使用简单的问题:

UPDATE Table SET Counter = Counter + 1  
Run Code Online (Sandbox Code Playgroud)

我已经构建了以下代码示例来尝试获取不一致的值并证明自己只使用这个简单的更新语句并不是一个好习惯:

class Program
{
    static void Main(string[] args)
        {
            List<Task> tasks = new List<Task>();

            for (int i = 0; i < 100; i++)
            {
                Task t = Task.Factory.StartNew(() =>
                {
                    WriteToCounter();
                });

                tasks.Add(t);
            }

            Task.WaitAll(tasks.ToArray());
        }

    static void WriteToCounter()
        {
            string connString = ConfigurationManager.ConnectionStrings["DefaultConnection"].ConnectionString;

            using (SqlConnection connection = new SqlConnection(connString))
            {
                connection.Open();
                Random rnd = new Random();
                for (int i = 1; i <= 100; i++)
                {
                    int wait …
Run Code Online (Sandbox Code Playgroud)

sql transactions atomic sql-update

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

在DB2中更改列名

我需要重命名其中一个表的列名.我有DB2数据库,我们是与Eclipse IDE的连接数据库并执行sql查询.

谢谢

sql db2

6
推荐指数
1
解决办法
2万
查看次数

写选项卡分隔文件

我在编写制表符分隔文件时遇到问题,我在这里查了一下,还没有得到我的答案.

所以我有一个函数返回带有下面重要部分的字符串(使用分隔符以及我如何构建每一行):

var delimiter = @"\t";
sb.Append(string.Join(delimiter, itemContent));
sb.Append(Environment.NewLine);
Run Code Online (Sandbox Code Playgroud)

返回的字符串是这样的:

H\t13\t170000000000001\t20150630
D\t1050\t10.0000\tY
D\t1050\t5.0000\tN
Run Code Online (Sandbox Code Playgroud)

然后我用它写一个文件(下面的内容是上面的字符串):

var content = BuildFile(item);
var filePath = tempDirectory + fileName;

// Create the File
using (FileStream fs = File.Create(filePath))
{
    Byte[] info = new UTF8Encoding(true).GetBytes(content);
    fs.Write(info, 0, info.Length);
}
Run Code Online (Sandbox Code Playgroud)

但是,文件输出没有选项卡(在记事本++中打开):

H\t13\t170000000000005\t20150630
D\t1050\t20.0000\tN
D\t1050\t2.5000\tY
Run Code Online (Sandbox Code Playgroud)

当它应该更像这样(提供样本文件):

H   100115980   300010000000003 20150625
D   430181  1   N
D   342130  2   N
D   459961  1   N
Run Code Online (Sandbox Code Playgroud)

这可能是由我使用的编码引起的吗?感谢您的任何输入,谢谢!

c# file tab-delimited tab-delimited-text

3
推荐指数
2
解决办法
2万
查看次数

ASP.NET 5 MVC 6中的web.config

我有一个WCF .dll从web.config文件加载配置.
我在asp.net 5应用程序中使用该dll,当我尝试从dll调用函数时,我遇到异常:

找不到在ServiceModel客户端配置部分引用合同'WebService.MyWebService'的默认端点元素.这可能是因为没有为您的应用程序找到配置文件,或者因为在客户端元素中找不到与此合同匹配的端点元素.

dll的配置存在于web.config中.
这曾经在asp.net beta 6中工作,但现在我升级到rc1它不起作用.

我怎样才能做到这一点?

c# wcf asp.net-core-mvc kestrel-http-server asp.net-core

3
推荐指数
1
解决办法
1317
查看次数

您可以在GROUP BY中未列出的列上使用HAVING子句吗?

我有这个问题,我一直在努力,我找到的解决方案是每个Pecheur(渔夫)获得AVERAGE结果,是的,这有点可能是一个学校项目.我基本上需要每个渔民的名字和地址,每个渔民在每份合同(CONTRAT)上至少收取两项费用(FRAIS),并且在2000年至2002年期间每年平均需要2次捕鱼(贵重).必要的表列在from和JOIN中,我的问题是,我可以使用HAVING AVG(x)虽然x未列在Select也不在group by中,但只出现在FROM部分的表中.请注意,我没有真正的数据库来测试查询.

SELECT  pecheur.NOM as nom_Pecheur, 
        pecheur.ADRESSE as adresse

FROM    TP1_PECHEUR as pecheur
        INNER JOIN TP1_CONTRAT as contrat on pecheur.ID_PECHEUR=contrat.ID_PECHEUR
        INNER JOIN TP1_FRAIS_CONTRAT as frais_contrat on contrat.ID_CONTRAT=frais_contrat.ID_CONTRAT
        INNER JOIN TP1_FRAIS as frais on frais_contrat.ID_FRAIS=frais.ID_FRAIS
        INNER JOIN TP1_DECLARATION_PRISE as declaration_prise on pecheur.ID_PECHEUR=declaration_prise.ID_PECHEUR
        INNER JOIN TP1_PRISE as prise on declaration_prise.ID_DECLARATION_PRISE=prise.ID_DECLARATION_PRISE

WHERE   frais_contrat.ID IN ( SELECT  TP1_FRAIS_CONTRAT.ID, COUNT(*) as NB_FRAIS
                              FROM    TP1_FRAIS_CONTRAT
                              GROUP BY TP1_FRAIS_CONTRAT.ID
                              HAVING NB_FRAIS >= 2 )
        AND declaration_prise.DATE_DECLARATION BETWEEN '01-01-2000' AND '31-12-2002'

GROUP BY  nom_Pecheur

HAVING    AVG(prise.NOMBRE_POISSON) > …
Run Code Online (Sandbox Code Playgroud)

sql oracle group-by having

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

向SQL Server用户授予执行权限以仅运行特定作业

我有创建一个可由特定SQL用户运行的SQL Server代理作业的请求。

如何在不授予用户执行sp_start_job存储过程执行权限的情况下完成操作,这意味着他也可以运行所有其他禁止的作业?

sql sql-server jobs stored-procedures

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

如何将表头与表内容对齐?

因为我正在使用锚标签,所以我用div构建了一个表.显示为表格.不幸的是,标题与内容不一致.怎么了?

的jsfiddle

HTML

<div class="compare-table">
            <div class="row">
                <div class="tablehead">1 header</div>
                <div class="tablehead">2 header</div>
                <div class="tablehead">3 header</div>
                <div class="tablehead">4 header</div>
                <div class="tablehead">5 header</div>
            </div>
        </div>
   <div class="compare-table">                
            <a >
                <div class="cell">my value 1</div>
                <div class="cell">my value 2</div>
                <div class="cell">my value 3</div>
                <div class="cell">my value 4</div>
                <div class="cell">my value 5</div>
            </a>
</div>
Run Code Online (Sandbox Code Playgroud)

html css

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