主頁 > 企業開發 > 將相同型別的變體模板型別分組為<type,int>變體型別,從變體串列中省略<type,0>。

將相同型別的變體模板型別分組為<type,int>變體型別,從變體串列中省略<type,0>。

2021-10-15 16:10:49 企業開發

我正在實作編譯時的單位系統,我能夠將不同的單位相乘,例如:

我正在實作編譯時的單位系統。

Scalar<int, M_>{2}。*Scalar<int, M_>{2} ==Scalar<int, M_, M>{4};

我還希望能這樣做:

我希望能這樣做:

Scalar<int, M_, M_>{4}. / Scalar<int, M_>{2} == Scalar<int, M_>{2};

而我認為一個好的開始是將類似的單位歸入一個template< typename T, int P> struct UnitPower型別,以便

Scalar<int, UnitPower<M_, 1>>{2}。*Scalar<int, UnitPower<M_, 1>>{2} == Scalar< int, UnitPower<M_, 2> >{4};

而且

Scalar<int, UnitPower<M_, 2>>{4}。/ Scalar<int, UnitPower<M_, 1>>{2} == Scalar< int, UnitPower<M_, 1> >{2};

這將在一個更普遍的情況下派上用場:

Scalar<double, UnitPower< M_, 1> , UnitPower<S_, -2>, UnitPower<G_, 1>>{70}. / Scalar<double, UnitPower<M_, 1>, UnitPower<S_, -1>>{10} == Scalar< double, UnitPower<S_, -1>, UnitPower<G_, 1> >{7}.

我還需要使運算子與這些UnitPowers的順序無關。

到目前為止,代碼如下:

struct M_struct S_; struct Mps_; template<typename T, int P> struct UnitPower {}; template<typename T, int P, typename。R> struct group_units { //static constexpr type = ? }; template <typename T, class... C> struct Scalar { protected: T值。 public: constexpr explicit Scalarconst T value) : value(value) {}。 template<typename U> constexpr auto operator<=>(const Scalar<U, C...> rhs) { return value <=> static_cast<U>(rhs.value)。 } template<typename U> constexpr bool operator==(const Scalar<U, C. ...> rhs) const { return value == static_cast<T> (rhs); } template<typename U, typename.... D> constexpr Scalar<std::common_type_t<T, U> , C..., D... > operator/(const Scalar<U, D...> rhs) const{ using V = std::common_type_t<T, U> 。 return Scalar<V, C..., D...>{static_cast<V>(value) / static_cast<V>(rhs) }; } template<typename U, typename... D> constexpr Scalar<std::common_type_t<T, U> , C..., D... > operator*(constScalar<U, D...> rhs) const { using V = std::common_type_t<T, U> 。 return Scalar<V, C..., D...>{static_cast<V>(value) * static_cast<V>(rhs) }; } template<typename U> constexpr std::common_type_t<T, U> operator/(const Scalar< U, C. ...> rhs) const { using V = std::common_type_t<T, U> 。 return static_cast<V>(value) / static_cast<V>(rhs) 。 } template<typename U> constexpr Scalar<std::common_type_t<T, U>, C. 。 > operator/(const U rhs) const { using V = std::common_type_t<T, U> 。 return Scalar<V, C...>{static_cast<V>(value) / static_cast<V>(rhs) }; } constexpr explicit operator T() const{ return value; } template<typename U> constexpr explicit operator U() const{ return static_cast< U>(value); } }; template<typename T> struct Meters : Scalar<T, M_> { using Scalar<T, M_> :Scalar; }; template<typename T> struct Seconds : Scalar<T, S_> { using Scalar<T, S_> :Scalar; };

正如你所看到的,除法運算子目前只定義了相同的單位(以相同的順序),并且只回傳一個數字(在這種情況下是正確的回傳型別),或者只取一個數字,回傳Scalar而不修改單位,這也是正確的行為。

乘法運算子只是追加了單位,我需要它首先對它們進行分組。

我已經添加了

template<int P, typename T>
struct UnitPower {};

template<int P, typename T, typename。R>。
struct group_units {
   //static constexpr type = ?
};

一部分,但我真的不知道該如何去做。

我也不知道該如何去做。

我也不確定如何使操作者的單元順序不受影響。

在學習了如何對乘法運算子進行單位分組之后,除法運算子在單位方面將與乘法運算子類似--只是在右側使用負數。

因此,我的問題有兩個方面:

  • 如何使函式的單位順序不受影響?
  • 如何將類似的單位歸入UnitPower<U, int>結構,并省略功率為0的單位?(如果省略了所有的UnitPowers,則將Scalar衰減為基礎值型別)。
  • uj5u.com熱心網友回復:

    相當具有挑戰性...... 盡管我只做了一些基本的測驗,下面的代碼似乎是有效的,至少它應該給你一些如何解決這個問題的提示。還有相當多的潛力來美化代碼(盡管在最近的編輯中變得更少),我的模板的命名肯定是其他的,但不是最佳的 - 但我把這些留給你來解決... 作為一個小的補償部門,我們也已經提供了。

    這個想法總是基于同一個基本原則:我們需要遞回到模板引數中來進行我們需要的型別更改。牢記這一點,應該可以理解下面的代碼。如果還有問題,請隨時留言。

    template <typename Unit, int>
    struct UnitPower { };
    
    template <typename T, typename ...。單位>。
    struct Scalar
    {
        T值。
    };
    
    template <typename ... 單位>。
    struct concattemplate <typename ... 單位>。
    using concat_t = typename concat<Units...> :type。
    
    template <typename U, typename ...。單位>。
    struct concat<U, std::tuple<Units...>>。
    {
        using type = std::tuple<U, Units...>。
    };
    
    template <typename ... UnitsX, typename ...。UnitsY>
    struct concat<std::tuple<UnitsX...> , std::tuple<UnitsY...>>。
    {
        using type = std::tuple<UnitsX..., UnitsY...>。
    };
    
    template <typename ... 單位>。
    struct powerstemplate <typename ... 單位>。
    using powers_t = typename powers<Units...> :type。
    
    template <>
    struct powers<>
    {
        using type = std::tuple<> 。
    };
    
    template <typename U, typename ...。單位>。
    struct powers<U, Units...>
    {
        using type = concat_t<UnitPower<U, 1> , powers_t<Units...>。
    };
    
    template <typename U, int N, typename ... 單位>。
    struct powers<UnitPower<U, N> , Units...>
    {
        using type = concat_t<UnitPower<U, N>, powers_t<Units...> >。
    };
    
    template <typename ... 單位>。
    struct counttemplate <typename ... 單位>。
    using count_t = typename count<Units...> :type;
    
    template <typename U, int P>
    struct count<UnitPower<U, P> >
    {
        using type = UnitPower<U, P> 。
    };
    
    template <typename U, int PX, int PY, typename ...。單位>。
    struct count<UnitPower<U, PX> , UnitPower<U, PY> , Units...>
    {
        using type = count_t<UnitPower<U, PX   PY>, Units...> 。
    };
    
    template < typename UX, int PX, typename UY, int PY, typename 。 .. 單位>。
    struct count<UnitPower<UX, PX> , UnitPower<UY, PY> , Units...>
    {
        using type = count_t<UnitPower<UX, PX>, Units...> 。
    };
    
    template < typename ... 單位>。
    struct count<std::tuple<Units...>>。
    {
        using type = count_t<Units...>。
    };
    
    template <typename ... 單位>。
    struct remaintemplate <typename ... 單位>。
    using remain_t = typename remain<Units...> :type。
    
    template <typename U, int P>
    struct remain<UnitPower<U, P> >
    {
        using type = std::tuple<>。
    };
    
    template <typename U, int PX, int PY, typename ...。單位>。
    struct remain<UnitPower<U, PX> , UnitPower<U, PY> , Units...>
    {
        using type = remain_t<UnitPower<U, PX>, Units...> 。
    };
    
    template < typename UX, int PX, typename UY, int PY, typename . .. 單位>。
    struct remain<UnitPower<UX, PX> , UnitPower<UY, PY> , Units...>
    {
        using type = concat_t<
            UnitPower<UY, PY>。
            remain_t< UnitPower<UX, PX>, Units...>
        >。
    };
    
    template < typename ... 單位>。
    struct remain<std::tuple<Units...>>。
    {
        using type = remain_t<Units...> 。
    };
    
    template <typename ... 單位>。
    struct combinetemplate <typename ... 單位>。
    using combine_t = typename combine<Units...> :type。
    
    template <>
    struct combine<>
    {
        using type = std::tuple<> 。
    };
    
    template <typename U, int P>
    struct combine<UnitPower<U, P> >
    {
        using type = std::tuple<UnitPower<U, P>> 。
    };
    
    template <typename U, int P, typename ...。單位>。
    struct combine<UnitPower<U, P> , Units...>
    {
        using type = concat_t<
            count_t<UnitPower<U, P>, Units...> 。
            combine_t<remain_t<UnitPower<U, P>, Units...>>。
        >。
    };
    
    template <typename ... 單位>。
    struct combine<std::tuple<Units...>>。
    {
        using type = combine_t<Units...>。
    };
    
    template <typename ... 單位>。
    struct normalizetemplate <typename ... 單位>。
    using normalize_t = typename normalize<Units...> ::type。
    
    template <>
    struct normalize<>
    {
        using type = std::tuple<> 。
    };
    
    template <typename U, typename ...。單位>。
    struct normalize<UnitPower<U, 0>, Units...>
    {
        using type = normalize_t<Units...>。
    };
    
    template <typename U, typename ... 單位>。
    struct normalize<UnitPower<U, 1>, Units...>
    {
        using type = concat_t<U, normalize_t< Units...>。
    };
    
    template <typename U, int N, typename ... 單位>。
    struct normalize<UnitPower<U, N> , Units...>
    {
        using type = concat_t<UnitPower<U, N>, normalize_t<Units...> > 。
    };
    
    template <typename ... 單位>。
    struct normalize<std::tuple<Units...>>。
    {
        using type = normalize_t<Units...>。
    };
    
    template <typename T, typename ... 單位>。
    struct scalartemplate <typename ... 單位>。
    using scalar_t = typename scalar<Units...> :type。
    
    template <typename T, typename ... 單位>。
    struct scalar<T, std::tuple<Units...>>。
    {
        using type = Scalar<T, Units...> 。
    };
    
    template <typename ... T>
    struct multiplytemplate <typename ... T>
    using multiply_t = typename multiply<T...> :type。
    
    template <typename TX, typename TY, typename ... UnitsX, typename ...。UnitsY>
    struct multiply<TX, TY, std::tuple<UnitsX...> , std::tuple<UnitsY...>>
    {
        using type = scalar_t<
            decltype(std::declval<TX>() * std::declval<TY>() 。)
            normalize_t<combine_t< concat_t<
                powers_t<UnitsX...>, powers_t<UnitsY...>。
            >>>。
        >。
    };
    
    template <typenameTX, typenameTY, typename ... UnitsX, typename ...。UnitsY>
    auto operator*(Scalar<TX, UnitsX...> x, Scalar< TY, UnitsY...> y)
        -> multiply_t<TX, TY, std::tuple<UnitsX...> , std::tuple<UnitsY...>>
    {
        return {x.value * y.value};
    }
    
    template <typename ...。單位>。
    struct negatetemplate <typename ... 單位>。
    using negate_t = typename negate<Units...> :type;
    
    template <>
    struct negate<>
    {
        using type = std::tuple<> 。
    };
    
    template <typename U, int N, typename ...。單位>。
    struct negate<UnitPower<U, N>, Units... >
    {
        using type = concat_t<UnitPower<U, -N>, negate_t<Units...>> 。
    };
    
    template <typename ... 單位>。
    struct negate<std::tuple<Units...>>。
    {
        using type = negate_t<Units...> 。
    };
    
    template <typename ... T>
    struct dividetemplate <typename ... T>
    using divide_t = typename divide<T...> :type。
    
    template <typename TX, typename TY, typename ... UnitsX, typename ...。UnitsY>
    struct divide<TX, TY, std::tuple<UnitsX...> , std::tuple<UnitsY...>>
    {
        using type = scalar_t<
            decltype(std::declval<TX>() / std::declval<TY>() ) 。
            normalize_t<combine_t< concat_t<
                powers_t<UnitsX...>, negate_t<powers_t<UnitsY...> >
            >>>。
        >。
    };
    
    template <typenameTX, typenameTY, typename ... UnitsX, typename ...。UnitsY>
    auto operator/(Scalar<TX, UnitsX...> x, Scalar< TY, UnitsY...> y)
        -> divide_t<TX, TY, std::tuple<UnitsX...> , std::tuple<UnitsY...>>
    {
        return {x.value / y.value};
    }
    
    

    uj5u.com熱心網友回復:

    這是我想出來的。

    這是我想出來的。

    #include <tuple>
    #include <type_traits>
    
    template <typename T, typename Tuple>
    struct remove_from_tuple;
    template <typename T, typename Tuple>
    using remove_from_tuple_t = typename remove_from_tuple<T, Tuple> ::type;
    
    template <typename T, typename...。ElemT>
    struct remove_from_tuple<T, std::tuple<ElemT...>> {
        using type = decltype(std::tuple_cat(std::declval<
            std::conditional_t<std::is_same_v<T, ElemT>, std::tuple<>, std::tuple<elemT>>
            >()...))。
        static constexpr std::size_t removed =
            sizeof...(ElemT) - std::tuple_size<type> ::value。
    };
    
    template <class Tuple1, class Tuple2>
    struct is_tuple_permutation : std::false_type {};
    template <class Tuple1, class Tuple2>
    constexpr bool is_tuple_permutation_v = is_tuple_permutation<Tuple1, Tuple2> ::value。
    
    template<>
    struct is_tuple_permutation<std::tuple<>, std::tuple<>
        : public std::true_type {};
    
    template <typename T, typename.... List1, typename Tuple2>
    struct is_tuple_permutation<std::tuple<T, List1...> , Tuple2> {
    private:
        using remove1_t = remove_from_tuple<T, std::tuple<List1...>>。
        使用 remove2_t = remove_from_tuple<T, Tuple2>。
    public:
        static constexpr bool value =
            1   remove1_t::removed == remove2_t::removed&&
            is_tuple_permutation_v<typename remove1_t::type, typename remove2_t::type>。
    };
    
    結構 M_結構 S_;
    struct KG_;
    
    template <class Tag, int P>
    struct UnitPower {};
    
    //Trait: UnitPower<Tag0, P0>, UnitPower<Tag1, P1>, ...。-> Tag0
    template <class。單位>。
    struct first_tagtemplate <class... 單位>。
    using first_tag_t = typename first_tag<Units...>:type。
    template <class Tag0, int P0, class ... 單位>。
    struct first_tag<UnitPower<Tag0, P0> , Units...> {
        using type = Tag0;
    };
    
    // 特質。所有具有匹配標簽的UnitPower在單位中的權力總和......;
    //將所有具有不同Tag的Unit...放入元組余數中。
    template <class Tagclass... 單位>。
    struct collect_unittemplate <class Tagclass... 單位>。
    constexpr int collect_unit_power = collect_unit<Tag, Units...>:power。
    template <class Tagclass... 單位>。
    using collect_unit_remainder_t = typename collect_unit<Tag, Units...>::remainder。
    
    template <class Tag>
    struct collect_unit< Tag> {
        static constexpr int power = 0;
        using remainder = std::tuple<> 。
    };
    
    template <class Tag, int P0, class... 單位>。
    struct collect_unit<Tag, UnitPower<Tag, P0>, Units...> {
        static constexpr int power = P0   collect_unit_power<Tag, Units...> 。
        using remainder = collect_unit_remainder_t<Tag, Units...> 。
    };
    
    template < class Tag, class Unit0, class. .. 單位>。
    struct collect_unit<Tag, Unit0, Units...> {
        static constexpr int power = collect_unit_power<Tag, Units...> 。
        using remainder = decltype(std::tuple_cat(
            std::declval<std::tuple<Unit0>>()。
            std::declval<collect_unit_remainder_t<Tag, Units...>>()))。)
    };
    
    // 特質。結合任何具有相同Tag的單位。
    template <class Tuple>
    struct group_unitstemplate <class Tuple>
    using group_units_t = typename group_units<Tuple> ::type。
    
    template<>
    struct group_units<std::tuple<> > {
        using type = std::tuple<>。
    };
    
    template <class。單位>。
    struct group_units<std::tuple<Units...> > {
    private:
        using Tag0 = first_tag_t<Units...> 。
        using collect_t = collect_unit<Tag0, Units...> 。
    public:
        using type = decltype(std::tuple_cat(
            std::declval<std::conditional_t<
                collect_t::power != 0,
                std::tuple<UnitPower<Tag0, collect_t::power>> 。
                std::tuple<>>>()。
            std::declval<group_units_t<typename collect_t:: remainder>()))。)
    };
    
    template <typename T, class ... 單位>。
    class Scalar// 特質。兩個Scalars是否具有相同的基礎型別和相同的單位//以任何順序?template <class S1, class S2>
    struct Scalars_compatible : public std::false_type{};
    template <class S1, class S2>
    constexpr bool Scalars_compatible_v = Scalars_compatible<S1, S2> ::value。
    
    template <typename T1, class. Units1, typename T2, class...。Units2>。
    struct Scalars_compatible<Scalar<T1, Units1...>, Scalar<T2, Units2...> >
        : public std::bool_constant<is_tuple_permutation_v<
             std::tuple<Units1...>, std::tuple<Units2...>>>
    {};
    
    template <typename T, class Tuple>
    struct tuple_to_Scalar;
    template <typename T, class Tuple>
    using tuple_to_Scalar_t = typename tuple_to_Scalar<T, Tuple> ::type;
    
    template <typename T, class. 單位>。
    struct tuple_to_Scalar<T, std::tuple<Units...> > {
        using type = Scalar<T, Units...> 。
    };
    
    template <class S1, class S2>
    struct Scalar_producttemplate <class S1, class S2>
    using Scalar_product_t = typename Scalar_product<S1, S2> ::type;
    
    template <typename T1, class. Units1, typename T2, class...。Units2>。
    struct Scalar_product<Scalar<T1, Units1...>, Scalar<T2, Units2...> > {
        using type = tuple_to_Scalar_t<
            std::common_type_t<T1, T2> 。
            group_units_t<std::tuple<Units1..., Units2...>> 。
    };
    
    template <class Unit>
    struct invert_unittemplate <class Unit>
    using invert_unit_t = typename invert_unit< Unit>:type。
    
    template <class Tag, int P>
    struct invert_unit<UnitPower<Tag, P> > {
        using type = UnitPower<Tag, -P> 。
    };
    
    template <class S1, class S2>
    struct Scalar_quotienttemplate <class S1, class S2>
    using Scalar_quotient_t = typename Scalar_quotient<S1, S2> ::type;
    
    template <typename T1, class. Units1, typename T2, class...。Units2>。
    struct Scalar_quotient<Scalar<T1, Units1...> , Scalar<T2, Units2...> > {
        using type = tuple_to_Scalar_t<
            std::common_type_t<T1, T2> 。
            group_units_t<std::tuple<Units1..., invert_unit_t<Units2> ...>>。
    };
    
    using Distance_t = Scalar<double, UnitPower<M_, 1> > 。
    using Time_t = Scalar<double, UnitPower<S_, 1> >。
    使用Speed_t = Scalar_quotient_t<Distance_t, Time_t>。
    using Acceleration_t = Scalar_quotient_t<Speed_t, Time_t>;
    using Mass_t = Scalar<double, UnitPower<KG_, 1> > 。
    using Energy_t = Scalar_product_t<Mass_t, Acceleration_t> 。
    static_assert(Scalars_compatible_v<Energy_t, Scalar<double, UnitPower< KG_, 1>, UnitPower<M_, 1>, UnitPower<S_, -2> >)。
    static_assert(Scalars_compatible_v<Scalar_quotient_t<Speed_t, Acceleration_t>, Time_t>) 。
    

    注意你可能想限制你的operator , operator==, 等等需要Scalars_compatible_v

    轉載請註明出處,本文鏈接:
    https://www.uj5u.com/qiye/315763.html

    標籤:

    上一篇:C 嵌套SFINAE模板產生的編譯錯誤

    下一篇:前端實作很哇塞的瀏覽器端掃碼功能🌟

    標籤雲
    其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

    熱門瀏覽
    • IEEE1588PTP在數字化變電站時鐘同步方面的應用

      IEEE1588ptp在數字化變電站時鐘同步方面的應用 京準電子科技官微——ahjzsz 一、電力系統時間同步基本概況 隨著對IEC 61850標準研究的不斷深入,國內外學者提出基于IEC61850通信標準體系建設數字化變電站的發展思路。數字化變電站與常規變電站的顯著區別在于程序層傳統的電流/電壓互 ......

      uj5u.com 2020-09-10 03:51:52 more
    • HTTP request smuggling CL.TE

      CL.TE 簡介 前端通過Content-Length處理請求,通過反向代理或者負載均衡將請求轉發到后端,后端Transfer-Encoding優先級較高,以TE處理請求造成安全問題。 檢測 發送如下資料包 POST / HTTP/1.1 Host: ac391f7e1e9af821806e890 ......

      uj5u.com 2020-09-10 03:52:11 more
    • 網路滲透資料大全單——漏洞庫篇

      網路滲透資料大全單——漏洞庫篇漏洞庫 NVD ——美國國家漏洞庫 →http://nvd.nist.gov/。 CERT ——美國國家應急回應中心 →https://www.us-cert.gov/ OSVDB ——開源漏洞庫 →http://osvdb.org Bugtraq ——賽門鐵克 →ht ......

      uj5u.com 2020-09-10 03:52:15 more
    • 京準講述NTP時鐘服務器應用及原理

      京準講述NTP時鐘服務器應用及原理京準講述NTP時鐘服務器應用及原理 安徽京準電子科技官微——ahjzsz 北斗授時原理 授時是指接識訓通過某種方式獲得本地時間與北斗標準時間的鐘差,然后調整本地時鐘使時差控制在一定的精度范圍內。 衛星導航系統通常由三部分組成:導航授時衛星、地面檢測校正維護系統和用戶 ......

      uj5u.com 2020-09-10 03:52:25 more
    • 利用北斗衛星系統設計NTP網路時間服務器

      利用北斗衛星系統設計NTP網路時間服務器 利用北斗衛星系統設計NTP網路時間服務器 安徽京準電子科技官微——ahjzsz 概述 NTP網路時間服務器是一款支持NTP和SNTP網路時間同步協議,高精度、大容量、高品質的高科技時鐘產品。 NTP網路時間服務器設備采用冗余架構設計,高精度時鐘直接來源于北斗 ......

      uj5u.com 2020-09-10 03:52:35 more
    • 詳細解讀電力系統各種對時方式

      詳細解讀電力系統各種對時方式 詳細解讀電力系統各種對時方式 安徽京準電子科技官微——ahjzsz,更多資料請添加VX 衛星同步時鐘是我京準公司開發研制的應用衛星授時時技術的標準時間顯示和發送的裝置,該裝置以M國全球定位系統(GLOBAL POSITIONING SYSTEM,縮寫為GPS)或者我國北 ......

      uj5u.com 2020-09-10 03:52:45 more
    • 如何保證外包團隊接入企業內網安全

      不管企業規模的大小,只要企業想省錢,那么企業的某些服務就一定會采用外包的形式,然而看似美好又經濟的策略,其實也有不好的一面。下面我通過安全的角度來聊聊使用外包團的安全隱患問題。 先看看什么服務會使用外包的,最常見的就是話務/客服這種需要大量重復性、無技術性的服務,或者是一些銷售外包、特殊的職能外包等 ......

      uj5u.com 2020-09-10 03:52:57 more
    • PHP漏洞之【整型數字型SQL注入】

      0x01 什么是SQL注入 SQL是一種注入攻擊,通過前端帶入后端資料庫進行惡意的SQL陳述句查詢。 0x02 SQL整型注入原理 SQL注入一般發生在動態網站URL地址里,當然也會發生在其它地發,如登錄框等等也會存在注入,只要是和資料庫打交道的地方都有可能存在。 如這里http://192.168. ......

      uj5u.com 2020-09-10 03:55:40 more
    • [GXYCTF2019]禁止套娃

      git泄露獲取原始碼 使用GET傳參,引數為exp 經過三層過濾執行 第一層過濾偽協議,第二層過濾帶引數的函式,第三層過濾一些函式 preg_replace('/[a-z,_]+\((?R)?\)/', NULL, $_GET['exp'] (?R)參考當前正則運算式,相當于匹配函式里的引數 因此傳遞 ......

      uj5u.com 2020-09-10 03:56:07 more
    • 等保2.0實施流程

      流程 結論 ......

      uj5u.com 2020-09-10 03:56:16 more
    最新发布
    • 使用Django Rest framework搭建Blog

      在前面的Blog例子中我們使用的是GraphQL, 雖然GraphQL的使用處于上升趨勢,但是Rest API還是使用的更廣泛一些. 所以還是決定回到傳統的rest api framework上來, Django rest framework的官網上給了一個很好用的QuickStart, 我參考Qu ......

      uj5u.com 2023-04-20 08:17:54 more
    • 記錄-new Date() 我忍你很久了!

      這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 大家平時在開發的時候有沒被new Date()折磨過?就是它的諸多怪異的設定讓你每每用的時候,都可能不小心踩坑。造成程式意外出錯,卻一下子找不到問題出處,那叫一個煩透了…… 下面,我就列舉它的“四宗罪”及應用思考 可惡的四宗罪 1. Sa ......

      uj5u.com 2023-04-20 08:17:47 more
    • 使用Vue.js實作文字跑馬燈效果

      實作文字跑馬燈效果,首先用到 substring()截取 和 setInterval計時器 clearInterval()清除計時器 效果如下: 實作代碼如下: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta ......

      uj5u.com 2023-04-20 08:12:31 more
    • JavaScript 運算子

      JavaScript 運算子/運算子 在 JavaScript 中,有一些運算子可以使代碼更簡潔、易讀和高效。以下是一些常見的運算子: 1、可選鏈運算子(optional chaining operator) ?.是可選鏈運算子(optional chaining operator)。?. 可選鏈操 ......

      uj5u.com 2023-04-20 08:02:25 more
    • CSS—相對單位rem

      一、概述 rem是一個相對長度單位,它的單位長度取決于根標簽html的字體尺寸。rem即root em的意思,中文翻譯為根em。瀏覽器的文本尺寸一般默認為16px,即默認情況下: 1rem = 16px rem布局原理:根據CSS媒體查詢功能,更改根標簽的字體尺寸,實作rem單位隨螢屏尺寸的變化,如 ......

      uj5u.com 2023-04-20 08:02:21 more
    • 我的第一個NPM包:panghu-planebattle-esm(胖虎飛機大戰)使用說明

      好家伙,我的包終于開發完啦 歡迎使用胖虎的飛機大戰包!! 為你的主頁添加色彩 這是一個有趣的網頁小游戲包,使用canvas和js開發 使用ES6模塊化開發 效果圖如下: (覺得圖片太sb的可以自己改) 代碼已開源!! Git: https://gitee.com/tang-and-han-dynas ......

      uj5u.com 2023-04-20 08:01:50 more
    • 如何在 vue3 中使用 jsx/tsx?

      我們都知道,通常情況下我們使用 vue 大多都是用的 SFC(Signle File Component)單檔案組件模式,即一個組件就是一個檔案,但其實 Vue 也是支持使用 JSX 來撰寫組件的。這里不討論 SFC 和 JSX 的好壞,這個仁者見仁智者見智。本篇文章旨在帶領大家快速了解和使用 Vu ......

      uj5u.com 2023-04-20 08:01:37 more
    • 【Vue2.x原始碼系列06】計算屬性computed原理

      本章目標:計算屬性是如何實作的?計算屬性快取原理以及洋蔥模型的應用?在初始化Vue實體時,我們會給每個計算屬性都創建一個對應watcher,我們稱之為計算屬性watcher ......

      uj5u.com 2023-04-20 08:01:31 more
    • http1.1與http2.0

      一、http是什么 通俗來講,http就是計算機通過網路進行通信的規則,是一個基于請求與回應,無狀態的,應用層協議。常用于TCP/IP協議傳輸資料。目前任何終端之間任何一種通信方式都必須按Http協議進行,否則無法連接。tcp(三次握手,四次揮手)。 請求與回應:客戶端請求、服務端回應資料。 無狀態 ......

      uj5u.com 2023-04-20 08:01:10 more
    • http1.1與http2.0

      一、http是什么 通俗來講,http就是計算機通過網路進行通信的規則,是一個基于請求與回應,無狀態的,應用層協議。常用于TCP/IP協議傳輸資料。目前任何終端之間任何一種通信方式都必須按Http協議進行,否則無法連接。tcp(三次握手,四次揮手)。 請求與回應:客戶端請求、服務端回應資料。 無狀態 ......

      uj5u.com 2023-04-20 08:00:32 more