xutility(2227):警告C4996:'std :: _ Copy_impl'

时间:2012-09-04 19:38:55

标签: c++ boost warnings base64

我收到了这条警告信息..但我不知道问题在哪里/哪里..!

包括

#pragma warning(push)
#pragma warning(disable:4996) 
#include <boost/archive/iterators/base64_from_binary.hpp>
#include <boost/archive/iterators/insert_linebreaks.hpp>
#include <boost/archive/iterators/transform_width.hpp>
#include <boost/archive/iterators/ostream_iterator.hpp>
#pragma warning(pop)

和警告

1>c:\program files (x86)\microsoft visual studio 10.0\vc\include\xutility(2227): warning C4996: 'std::_Copy_impl': Function call with parameters that may be unsafe - this call relies on the caller to check that the passed values are correct. To disable this warning, use -D_SCL_SECURE_NO_WARNINGS. See documentation on how to use Visual C++ 'Checked Iterators'
1>          c:\program files (x86)\microsoft visual studio 10.0\vc\include\xutility(2212): Siehe Deklaration von 'std::_Copy_impl'
1>          c:\users\perlig\documents\visual studio 2010\projects\restmanager\restmanager\**http.cpp(257)**: Siehe Verweis auf die Instanziierung der gerade kompilierten Funktions-template "_OutIt std::copy<boost::archive::iterators::insert_linebreaks<Base,N>,boost::archive::iterators::ostream_iterator<Elem>>(_InIt,_InIt,_OutIt)".
1>          with
1>          [
1>              _OutIt=boost::archive::iterators::ostream_iterator<char>,
1>              Base=boost::archive::iterators::base64_from_binary<boost::archive::iterators::transform_width<const char *,6,8>>,
1>              N=76,
1>              Elem=char,
1>                _InIt=boost::archive::iterators::insert_linebreaks<boost::archive::iterators::base64_from_binary<boost::archive::iterators::transform_width<const char *,6,8>>,76>
1>          ]

代码出现在第257行,如警告信息所示。但我无法解决它因为我不知道出了什么问题。

字符串数据包含一个“user:password”字符串,用于通过http。

进行基本身份验证

http.cpp(257):

// typdef, prepare
using namespace boost::archive::iterators;
stringstream os;
typedef 
    insert_linebreaks<         // insert line breaks every 72 characters
        base64_from_binary<    // convert binary values ot base64 characters
            transform_width<   // retrieve 6 bit integers from a sequence of 8 bit bytes
                const char *,
                6,
                8
            >
        > 
        ,76
    > 
    base64_text; // compose all the above operations in to a new iterator

// encrypt
#pragma warning(push)
#pragma warning(disable:4996)
copy( //<<<<<------ LINE 257
    base64_text(data.c_str()),
    base64_text(data.c_str() + data.size()),
    boost::archive::iterators::ostream_iterator<char>(os)
);
#pragma warning(pop)

任何人都有任何想法?

1 个答案:

答案 0 :(得分:12)

我想您知道警告的含义是什么,但首先我描述警告,然后说出如何摆脱警告。 Microsoft在其CRT,STL,MFC等中实现了一组新的安全功能,并将这些功能的旧版本标记为已弃用,以便为您提供应迁移到新安全版本的提示。所以它说std :: copy是不安全的!怎么样?如下:

char storage[ 10 ], *p = storage;
std::copy( std::istream_iterator<int>(std::cin), std::istream_iterator<int>(), p );

现在如果用户输入超过10个int将会发生什么?记忆将被覆盖,你的内存也会被破坏。

使用boost::archive::iterators::ostream_iterator是完全安全的,但由于它不遵循MSVC中安全迭代器的设计,因此它将被视为不安全。

现在您应该通过-D_SCL_SECURE_NO_WARNINGScl输入标志禁用此警告,或添加pragma以禁用此警告(就像您一样),但为什么编译指示不起作用?

原因很明显,这个pragma在范围和你使用pragma的范围上的工作没有错,你必须使用这个pragma保护xutility并且每个东西都会按预期工作。