Disclaimer

Any opinions expressed here are my own and not necessarily those of my employer (I'm self-employed).

Jul 29, 2012

Generating secure Guids

Guids are used extensively throughout Microsoft systems and developers tend to turn to Guid.NewGuid() whenever they need to create a value to uniquely identify something. Guids might also be used as keys or identifiers in security critical operations — under the assumption that they are hard to guess for an attacker. I've been looking around the Internet to see if I could find some guidance on Guid security along with details on how they are generated in the .NET framework. I couldn't find much information, but I did find that Eric Lippert from the C# team recently raised some concerns about the Guids on his blog. So I started digging around to see what more I could find out.

First of all a quick background. Microsoft's Guid is their implementation of the Universally Unique IDentifier (UUID) outlined in RFC 4122. UUIDs are 128 bits, and the Guid class generates version 4 UUIDs, meaning that all bits except those defining the version and variant of the UUID are "random." Please note that 4 bits are used for the version number, and two bits are used for the variant — so it's not a 128 bit random number, it's a 122 bit random number.

I looked into how these Guids are created in the .NET framework. Turns out Guid.NewGuid() simply calls the CoCreateGuid  function on the native ole32.dll, which in turn calls the RPC function UuidCreate. And from its remarks:
The UuidCreate function generates a UUID that cannot be traced to the ethernet address of the computer on which it was generated. It also cannot be associated with other UUIDs created on the same computer. 
Some care has been taken when generating these Guids, but the documentation is far from fullfilling. It's still unclear how easy they are to predict. So, assuming that we cannot trust Guids to be all that "secure", what to do? I've looked around for code that generates a Guid based on the output of a cryptographically strong RNG but couldn't find a good example — so I wrote my own generator that uses the RngCryptoServiceProvider. That way, we know where the bits are coming from. Since it generates proper Guid instances it should be fairly easy to plug it into existing code, e.g. replacing Guid.NewGuid() with SecureGuid.NewGuid(). Also remember to look out for Guids created by constructor: new Guid().

The code

Here's what the code could look like if you wanted to generate a GUID using random bytes from the frameworks's cryptograpically strong RNG. Note the first four bits of the time_hi_and_ver variable is set to version number four, and the first two bits of byte number eight is set according to the variant. Have a look at  RFC 4122  for more details. Apart from that, the code should be straightforward to understand.

using System;
using System.Security.Cryptography;

namespace SecureGuidDemo
{
    class SecureGuid
    {

        public static Guid NewGuid()
        {
            byte[] bytes = { 0x00, 0x00, 0x00, 0x00,
                               0x00, 0x00, 0x00, 0x00,
                               0x00, 0x00, 0x00, 0x00,
                               0x00, 0x00, 0x00, 0x00 };

            using (var rng = new RNGCryptoServiceProvider())
            {
                rng.GetBytes(bytes);
                
            }
            var time = BitConverter.ToUInt32(bytes,0);
            var time_mid = BitConverter.ToUInt16(bytes,4);
            var  time_hi_and_ver = BitConverter.ToUInt16(bytes,6);
            time_hi_and_ver = (ushort)((time_hi_and_ver | 0x4000) & 0x4FFF);
            
            bytes[8] = (byte)((bytes[8] | 0x80) & 0xBF);
            
            return new Guid(time,time_mid,time_hi_and_ver,
                bytes[8],bytes[9],bytes[10],bytes[11],bytes[12],bytes[13],
                bytes[14],bytes[15]);
        }
    }
}

You might look at the code and find it funny that I used the constructor that takes an int, short, short, and byte's. The reason is that I found a bug when creating Guids based on byte arrays. The above code does not trigger the bug, so it should work now and should also work after the bug is fixed (if they decide to do so). I'm in the process of verifying the bug with Microsoft, I'll probably put something up on my blog about it when that's settled.

243 comments:

  1. This is awesome!! really helpful for me. Thanks for sharing with us. Following links also helped me to complete my task.

    http://msdn.microsoft.com/en-IN/library/system.guid(v=vs.71).aspx
    http://www.mindstick.com/Articles/93446478-8ec4-4f1d-b87f-8248e0f7d6ad/?GUID%20in%20NET

    ReplyDelete
  2. how can i use this sample for 32 bit GUID

    ReplyDelete
    Replies
    1. If you are looking for attractive and sizzling Goa escorts so don't worry, we are here to provide you best Goa call girls. We have practical experience in offering tasteful and simple admittance to the absolute best Lucknow escorts at your place. Lucknow Call Girls is the best individuals who may never mind to give you the sprightly sort of opinion and fun finally.

      Delete
  3. Replies
    1. If you're alone and searching for somebody for accompanying you, then you'll just visit here and choose a
      GFE Goa call girl service as per your needs.
      OR
      Just call or WhatsApp right now to GFE Goa escort service, if you want to enjoy with them.

      AND
      you can also contact for GFE Lucknow Escort service or GFE Lucknow call girl service for enjoyment in nawab city.

      Delete
  4. Get all necessary information about WebWatcher app here.

    ReplyDelete
  5. Very informative, keep posting such good articles, it really helps to know about things.

    ReplyDelete
  6. It's a great site .. Design looks very good .. Continue to work so!

    ReplyDelete
  7. • Assignments are often considered the burden on the mind of students not giving them ample time for any other activities. Lack of time denies students from performing their beloved hobbies, ceasing them from participating in any sports, cultural affairs. Hence, no overall growth for them. Online Assignment help

    ReplyDelete
  8. Get the best essay writing NZ services from the experts of Students Assignment Help and make your academic life easier. Send us your assignment request at info@studentsassignmenthelp.com or WhatsApp at +44-755-536-9184

    ReplyDelete
  9. Avail the best Australian Assignment Help services in Australia by top rated experts at cheapest prices at Myassignmenthelp.com. MyAssignmenthelp most trusted online assignment writing company provides the assignment writing help service for students in Australia of all levels, starting from high school till Ph.D. Our professional academic assignment helper prepares custom written assignment exclusively for you to achieve A+ grade

    ReplyDelete
  10. Students Assignment Help provides the write my essay NZ services to the students of various universities at a low price. Our highly-experienced writers are available 24x7 for guiding the students for any academic help.

    ReplyDelete
  11. ac Market is a standout among the best outsider application stores which enable Android clients to ac market download broke applications, hacked diversions and numerous mods of recreations and applications for absolutely free of expense. Air conditioning Market is the best option in contrast to the Google Play Store.

    ReplyDelete
  12. Our assignment help experts could address students' academic topics quite well. Thus, they can opt for our service if they have difficulty in writing the academic task.
    assignment help

    ReplyDelete
  13. My Assignment Services is your first and last destination for every query you have related to ‘assignment help’ because we guarantee you the low-cost possible price of Assignment Writers Australia with the unmatched quality of assignments in Australia.

    ReplyDelete
  14. Loss of time denies college students from appearing their loved hobbies, ceasing them from collaborating in any sports, cultural affairs. Control and other associated fields. We offer Best Dissertation Writing Services UK technical and creative offerings ranging from net advertising to conversation maneuver.

    ReplyDelete
  15. This comment has been removed by the author.

    ReplyDelete
  16. Generating secure Guids is entirely a different stuff for me. Nice presentation. Thanks for sharing. Essay Writing Service

    ReplyDelete
  17. 90minup ข่าวกีฬา ฟุตบอล ผลบอล วิเคราะห์บอล พรีเมียร์ลีก ฟุตบอลไทย
    ข่าวกีฬา
    ตารางคะแนน
    ฟุตบอลไทย
    ไฮไลท์ฟุตบอล
    ดูบอลออนไลน์
    ผลบอลสด
    90minup

    ReplyDelete
  18. This comment has been removed by the author.

    ReplyDelete
  19. We provide online assignment help which is not only reliable but comes at a highly affordable price. Students are normally dubious before assignment there finances projects to someone else, as the solution is unknown to them. However, we can assure you that our writers double check the work and never fail to please the clients. Whether you are enroll in under grad, masters or a post grad program, we have writers for all levels and all finance courses.
    For further information & queries, Visit our website finance assignment helper

    ReplyDelete
  20. Hey, very nice site. I came across this on Google, and I am stoked that I did. I will definitely be coming back here more often. Wish I could add to the conversation and bring a bit more to the table, but am just taking in as much info as I can at the moment. Thanks .

    DedicatedHosting4u.com

    ReplyDelete
  21. Our Pay for custom written college papers services makes your college life bearable and also receive the best assignment writing service fulfilling by enabling you to pass your exams and also in other research and essay writing tasks.

    ReplyDelete
  22. At Assignment studio we have a number of service’s that we have to offer, among them MyAssignmenthelp is one of the most in demand service that majority of the students inquire about.

    ReplyDelete
  23. Nice blog, thanks for sharing with us this interesting blog. Visit OGEN Infosystem for Website Designing and PPC Services in Delhi, India.
    Web Development Company

    ReplyDelete
  24. THanks for sharing this quality stuff..All the time we are just be here to share with you the pinoy channel hd replays and updates which you will be get online without getting any membership.

    ReplyDelete
  25. I am glad that I saw this post. It is informative blog for us and we need this type of blog thanks for share this blog, Keep posting such instructional blogs and I am looking forward for your future posts.
    Cyber Security Projects for Final Year

    JavaScript Training in Chennai

    Project Centers in Chennai

    JavaScript Training in Chennai

    ReplyDelete
  26. Custom Assignment Writing Service should also strive to ensure that all Custom Essay Service work meets the standards of the examining bodies.Hence ensure that all Research Papers for Sale submissions are unique and original.

    ReplyDelete
  27. Appslure is Best app development company in mumbai and you can get website development service at a very affordable price.
    App development company in mumbai

    ReplyDelete
  28. I want to develop an android game. Is ASP.Net is suitable for me? By: Masters dissertation writing services

    ReplyDelete
  29. CASA98 บริการ แทงบอลออนไลน์ แทงบอลเดี่ยว บอลเต็ง บอลสเต็ป
    casa98
    แทงบอลออนไลน์

    ReplyDelete
  30. untuk bisa bermain di situs osg777 tentunya anda membutuhkan user id untuk bisa masuk kedalam permainan untuk itu silahkan melakukan daftar akun.

    osg777 yang berisi berbagai macam permaianan yang dapat anda pilih dan mainkan seperti tembak ikan, slot, live casino, mini games, serta e-casino.

    osg777 selalu aktif setiap hari selama 24 jam penuh tanpa ada hari libur sehingga dapat dimanfaatkan ketika pemain mau melakukan deposit slots uang asli lainnya.

    osg777 bandar slot yang sedang populer saat ini dengan keunggulan game yang menarik, ratusan judul game, jumlah payline yang bisa anda pilih dan bonus jackpot hingga ratusan juta.

    penyedia slot online populer saat ini osg777 menyediakan permainan slot paling lengkap dengan keunggulan tamnpilan grafis terbaik, slot tema menarik dan juga jumlah jackpot yang besar.

    ReplyDelete
  31. สล็อตออนไลน์ live22 ได้เงินจริงแสนสนุก
    https://www.slot4u.com/live22

    ReplyDelete
  32. Generally I don’t read post on blogs, but I wish to say that this write-up very compelled me to take a look at and do so! Your writing taste has been surprised me. Thank you, very great article.

    Sabung ayam online

    sbobet88
    bandar ayam
    sabung ayam
    adu ayam
    sabung taji
    s128
    website s128

    ReplyDelete
  33. I enjoyed over read your blog post. Your blog have nice information, I got good idea from this amazing blog.I am always searching like this type blog post. I hope I will see again…

    game android terbaik
    game pc terbaik

    ReplyDelete
  34. Halo semua, ini adalah kunjungan pertama saya untuk melihat blog ini; situs web ini mencakup
    materi yang luar biasa dan sebenarnya sangat baik untuk pengunjung.
    http://idntravel.org/

    ReplyDelete
  35. If you need any my assignment writing service related to Law, Human Resource, Leadership, Engineering, Marketing, Management, Finance, Economics or Accounts, we can help you out with it. If you are struggling with your University assignments and need Urgent Assignment Help then you are at the right place, with services like My Assignment Help,Assignment Help Australia and Essay help etc.
    Marketing assignment help
    Nursing assignment help
    Homework help
    Case Study help
    Urgent Assignment help
    Essay help online

    ReplyDelete
  36. Thank you for sharing such an informative Blog with us... I really like it very much..
    Readers if you guys are searching for
    IELTS,
    CELPIP ,
    PTE , and
    Spoken English Institute in Zirakpur and Panchkula ,

    Call Now :- +91 8288931000

    Thank you

    ReplyDelete
  37. You might feel like asking, “Can someone help me with my assignment” due to a lack of clear concept. Our assignment helpers are highly experienced and have a vast knowledge. Thus, they can easily prepare a highly informative assignment for you. With their help, you can also clear out all your concepts.

    Assignment help
    Online assignment help
    Essay help online

    ReplyDelete
  38. Awesome blog. I enjoyed reading your articles. This is truly a great read for me.I have bookmarked it and I am looking forward to reading new articles. Keep up the good work!
    eCommerce website designer in California | Website maintenance in California | Magento expert in California | Website maintenance in USA | eCommerce website designer in USA | Magento expert in USA |

    ReplyDelete
  39. Slotxo บริการ สล็อตออนไลน์ สล็อตxo แจกเครดิตฟรี พร้อม ทางเข้า slotxo เกมส์ใหม่กว่า 100 เกมส์ สมัคร slotxo ได้เลยตอนนี้ บริการ 24 ชั่วโมง.
    Slotxo
    สล็อตxo
    สล็อตxo บนมือถือ
    สมัคร slotxo
    สมัคร slotxo รับโบนัสฟรี

    ReplyDelete
  40. We should always share comprehensive and quality content which is liked by almost everyone and through such kind of content, we can get important information and improve our abilities. Master dissertation writing service.

    ReplyDelete
  41. Project Manager27 August, 2020 15:43

    I am very enjoying to read your well-written article posts. It seems that you devote a great deal of hard work and time onto your own blog.
    Learn PMP Certification in Hyderabad 360DigiTMG

    ReplyDelete
  42. du hoc canada vnsava
    Chuyên du học Canada Công ty tư vấn du học Canada nào tốt
    Điều kiện du học Canada 2021
    Học bổng du học Canada vnsava

    vnsava
    Thông tin du học Canada mới nhất

    vnsava
    Chính sách du học Canada 2020
    vnsava
    Du học Canada bao nhiêu tiền Việt
    Học bổng du học Canada 2020
    vnsava
    Du học Canada 2020
    Nhất ký du học Canada
    vnsava
    Du học Canada nên học ngành gì
    công ty tư vấn du học Canada vnsava, chính sách điều kiện định cư Canada, học bổng, chi phí, điều kiện xin visa canada
    #vnsava
    @vnsava
    vnsava
    vnsava
    vnsava

    ReplyDelete
  43. how to write an essay
    student doesn’t want to pay second time for the same course and aim to score good at any cost. These reasons get the students under tremendous pressure to secure A-grade paper in each semester.how to write an essay

    ReplyDelete
  44. this game is good สมัครpg
    this game is good joker123
    this game is good pg slot ทดลองเล่น
    this game is good pg auto
    this game is good joker gaming
    this game is good pgslot

    ReplyDelete
  45. Generally I don’t read post on blogs, but I wish to say that this write-up very compelled me to take a look at and do so! Your writing taste has been surprised me. Thank you, very great article.
    family lawyer
    annulment singapore
    child support singapore
    deed of separation singapore
    personal protection order singapore
    child maintenance

    ReplyDelete
  46. Nice Blog. If you want mobile game app, i want to recommend a company that is is a trusted Mobile game development company that offers scalable and custom game apps like PubG.

    ReplyDelete
  47. Get free bonus 100%
    New online slots game Online slot betting
    This game is very good Pgslot
    Get free bonus. Apply Pgslot auto
    this game is amazing UFABET
    This game is very good UFABET auto
    This game is very good GCLUB

    ReplyDelete
  48. I think it is very helpful. And thought that it could be applied as well pgslot
    I think it is very helpful. And thought that it could be applied as well joker gameing
    I think it is very helpful. And thought that it could be applied as well pgslot
    I think it is very helpful. And thought that it could be applied as well sexygame
    I think it is very helpful. And thought that it could be applied as well amp poker

    ReplyDelete
  49. An implementation of the universally unique ID that is computed by Windows and Windows applications. Using a pseudo-random 128-bit number, GUIDs are used to identify user accounts, documents, software, hardware, software interfaces, sessions, database keys and other items. I hope, you will understand it. Cheap essay writing UK.

    ReplyDelete
  50. เกมออนไลน์ ยอดฮิต ตู้สล็อต
    เกมออนไลน์ มาเก๊าคาสิโน
    วิธีเล่นได้เงินจริง โทนี่ บลูม

    ReplyDelete
  51. เกมส์ออนไลน์ ยอดฮิต superslot168

    ReplyDelete
  52. เว็บเกมส์ออนไลน์ superslot เครดิตฟรี

    ReplyDelete
  53. เกมยิงสุดมันส์ superslot ฟรี50

    ReplyDelete
  54. สล็อตออนไลน์ superslot777

    ReplyDelete
  55. School Management System
    If you’re looking for the best school management system in India, then go with Schoolzpro ERP. This ERP has different modules that help you manage and run all school tasks digitally. Using this ERP solution you can have one click look at attendance (both student & teacher), manage admissions, classrooms, fees, timetable, transport, online exams and much more. So, what are you waiting for? Try the Schoolzpro school management system today!
    https://schoolzpro.com/school-management-system/

    ReplyDelete
  56. Superb post! This post is very useful and I get interesting while reading it. Waiting for more post like this. Thanks for posting such a good post.
    To service your laptop with offer prices, Please visit : Laptop service center in Navalur

    ReplyDelete
  57. Typing Master 10 Crack might help consumers strengthen typing pace by accomplishing a ramification of checks and plans. It's really not giving only uncomplicated learning and training but moreover similar to a fun with all sorts of learning online games. The application is composed of all available education and learning compound to train you from zero talent to expert professional typist.

    ReplyDelete
  58. It is conceivably the quality spot in which you could find the quality young call girl in Goa.

    ReplyDelete
  59. Excellent Blog! I would like to thank you for the efforts you have made in writing this post. Gained lots of knowledge.
    Data Analytics Course

    ReplyDelete
  60. Awesome article. I enjoyed reading your articles. this can be really a good scan for me. wanting forward to reading new articles. maintain the nice work!
    Data Science Courses in Bangalore

    ReplyDelete

  61. I am sure it will help many people. Keep up the good work. It's very compelling and I enjoyed browsing the entire blog.
    Business Analytics Course in Bangalore

    ReplyDelete
  62. Thank a lot. You have done excellent job. I enjoyed your blog . Nice efforts
    Data Science Certification in Hyderabad

    ReplyDelete
  63. Wow, happy to see this awesome post. I hope this think help any newbie for their awesome work and by the way thanks for share this awesomeness, i thought this was a pretty interesting read when it comes to this topic. Thank you..
    Artificial Intelligence Course

    ReplyDelete
  64. I need to thank you for this very good read and i have bookmarked to check out new things from your post. Thank you very much for sharing such a useful article and will definitely saved and revisit your site.
    Data Science Course

    ReplyDelete
  65. You really made it seem so easy with your presentation, but I found this problem is actually something I thought I would never understand. It seems too complicated and very broad to me. I look forward to your next post, I will try to understand it!
    https://idntravel.asia/
    https://idntravel.info/
    https://idntravel.org/
    https://idngadget.org/
    https://idngamer.com/
    https://idntravel.net/
    https://christian-poker.net
    https://expekt-poker.com
    https://game2card.com

    ReplyDelete
  66. Wonderful blog found to be very impressive to come across such an awesome blog. I should really appreciate the blogger for the efforts they have put in to develop such amazing content for all the curious readers who are very keen on being updated across every corner. Ultimately, this is an awesome experience for the readers. Anyways, thanks a lot and keep sharing the content in the future too.

    Digital Marketing Training in Bangalore

    ReplyDelete
  67. I found Habit to be a transparent site, a social hub that is a conglomerate of buyers and sellers willing to offer digital advice online at a decent cost.

    Artificial Intelligence Training in Bangalore

    ReplyDelete
  68. Truly incredible blog found to be very impressive due to which the learners who go through it will try to explore themselves with the content to develop the skills to an extreme level. Eventually, thanking the blogger to come up with such phenomenal content. Hope you arrive with similar content in the future as well.

    Machine Learning Course in Bangalore

    ReplyDelete
  69. I bookmarked your website because this site contains valuable information. I am very satisfied with the quality and the presentation of the articles. Thank you so much for saving great things. I am very grateful for this site.

    Data Science Training in Bangalore

    ReplyDelete

  70. What an incredible message this is. Truly one of the best posts I have ever seen in my life. Wow, keep it up.
    AI Courses in Bangalore

    ReplyDelete
  71. I am sure it will help many people. Keep up the good work. It's very compelling and I enjoyed browsing the entire blog.
    Business Analytics Course in Bangalore

    ReplyDelete
  72. excellent blog thanks for information
    Deepam Oil

    ReplyDelete
  73. A good blog always contains new and exciting information and as I read it I felt that this blog really has all of these qualities that make a blog.

    Digital Marketing Institute in Bangalore

    ReplyDelete
  74. Many men and women struggle with physical effects of krokodil drug and alcohol use along with mental illness. In 2018, an estimated 9.2 million people in the U.S. struggled with co-occurring disorders like this, according to the Substance Abuse and mental Health Services Administration

    ReplyDelete
  75. The Law Essay Help - Buyessay.org.uk going great toward providing secure guide for payment system

    ReplyDelete
  76. pg game
    Thank you for good advice with only interesting stories.

    ReplyDelete
  77. I am here for the first time. I found this table and found it really useful and it helped me a lot. I hope to present something again and help others as you have helped me.

    Business Analytics Course in Nagpur

    ReplyDelete
  78. Assignments are challenging because it requires an in-depth understanding of everything that you have learnt in class and applying it in order to impress your professor. Your assignment submissions will have a lot of weight in the grades that you ultimately receive at the end of the program. And good grades are important to improve your employment prospects. To achieve this, it is therefore important to submit top quality assignments. However, assignment writing is not that simple and requires practice and a lot of experience. Any student who is looking for python homework help should immediately get in touch with Help in Homework

    ReplyDelete
  79. ที่สุดเกมแห่งยุค พร้อมแจกเครดิตให้คุณได้เปลี่ยนจากคนธรรมดา ให้กลายมาเป็นเศรษฐีได้ทันที เข้าเล่นแล้วที่ PGSLOTGAMES เว็บเกมรูปแบบใหม่ รองรับภาษาไทย กับอัตราการจ่ายเงินรางวัลที่สูง ลุ้นรับแจ๊กพ็อตได้ก่อนใคร ดาวน์โหลด

    ReplyDelete

Copyright notice

© André N. Klingsheim and www.dotnetnoob.com, 2009-2018. Unauthorized use and/or duplication of this material without express and written permission from this blog’s author and/or owner is strictly prohibited. Excerpts and links may be used, provided that full and clear credit is given to André N. Klingsheim and www.dotnetnoob.com with appropriate and specific direction to the original content.

Read other popular posts