How To Use DTOs In .NET REST APIs

Поділитися
Вставка
  • Опубліковано 12 чер 2023
  • 💻Watch the full tutorial: • ASP.NET Core Tutorial ...
    A Data Transfer Object, or DTO, represents a shared agreement between a client and a server about how data will be transferred and used.
    In this video I explain why you should use DTOs and then I go over a practical implementation in a simple C# based .NET REST API.
    🔥Become a Senior C# Backend Engineer: juliocasal.com/courses
    🗺️Get My Free .NET Backend Developer Roadmap: juliocasal.com/roadmap
    Join me on Patreon: / juliocasal
    Follow me on LinkedIn: / juliocasal
    Follow me on X: x.com/julioc
    #csharp #dotnet #aspnetcore

КОМЕНТАРІ • 37

  • @failscript
    @failscript 10 місяців тому +34

    By C# conventions you should use "toDTO" instead of "asDTO" since the method returns a new object. The "as" word is used for when you want to imply that something is being casted AS something.

    • @juliocasal
      @juliocasal  10 місяців тому +1

      Good call, agree!

  • @josecarlosmacoratti
    @josecarlosmacoratti 11 місяців тому +5

    Great !!! Using extension methods is the best way in a simple scenario .

  • @livan3li08
    @livan3li08 4 місяці тому +1

    can you share what the extension you use when creating c# files by right clicking in vs code explorer menu?

    • @juliocasal
      @juliocasal  4 місяці тому

      Here: marketplace.visualstudio.com/items?itemName=kreativ-software.csharpextensions

    • @livan3li08
      @livan3li08 4 місяці тому

      @@juliocasal thank you very much.

  • @saddamhossaindotnet
    @saddamhossaindotnet 10 місяців тому +1

    Great tutorial! Is it possible to utilize extension methods for complex DTO mapping without any external libraries? Do you consistently employ extension methods for DTOs without relying on any other mapping libraries?

    • @juliocasal
      @juliocasal  10 місяців тому

      Yes, absolutely

    • @goqsane
      @goqsane 8 місяців тому +1

      @@juliocasalthis is what we do too, extension methods .ToDto.

    • @juliocasal
      @juliocasal  8 місяців тому

      @@goqsaneGreat!

  • @faridulhuk1248
    @faridulhuk1248 11 місяців тому +1

    Is it possible to create Mapper for Mapping dto to Entity , reverse way

    • @juliocasal
      @juliocasal  11 місяців тому +1

      Everything is possible!

  • @podeig
    @podeig 8 місяців тому +2

    Super tutorial, Easy explained and precisely what I needed. Thank you!

  • @baranacikgoz
    @baranacikgoz 8 місяців тому +2

    I prefer project to dto feature of entity framework [ like _dbContext.MyUsers.Select(x => new MyDto(x.Name, x.Surname)) ], or you may achieve the same thing with dapper. No need for a dto conversion again in this way, unless you're dealing with in-memory collections

    • @juliocasal
      @juliocasal  8 місяців тому +1

      The data components should have no need to deal with DTOs, which goes for EF code too. Entity to DTO conversion is a higher level concern.

    • @pazzuto
      @pazzuto 6 місяців тому

      I do this for my "queries" (CQRS). I only bring back what I need from the database straight into a DTO whether it's EF, Dapper, or ADO. In some cases, I create a SQL View and I do a straight map. To alleviate the issue as Julio described for the endpoint changing, there's yet another object usually called a contract (following REPR): Entity Object -> DTO -> Response/Contract. But, I do use a DTO as the contract in lots of cases.

  • @torrvic1156
    @torrvic1156 5 місяців тому +1

    Thank you so much! That was exactly what I searched for but however I apologise sir but as far as I know it goes against the Clean Code principles to use decorations on your Entities. They should be as clear as possible because they correspond to the tables of your database. And is it Ok to use decorations with your DTOs also? Or do I don't understand something?
    And also why your records are not in different files but in one Julio? It looks not Ok in my opinion.

    • @juliocasal
      @juliocasal  5 місяців тому +1

      Yes, it would be best to keep the data annotations out of the entities. I don't see a problem with using them in DTOs.
      For a small set of DTOs, a single file is OK. If you have many, a file per DTO would be better.

  • @redouane5626
    @redouane5626 Рік тому +1

    I have habit that I do not use DTOs for API return types, instead I call them Models, is this right or wrong?

    • @juliocasal
      @juliocasal  Рік тому +4

      The name is not as important as the fact that you should not return the class that directly represents your DB schema. Sometimes I also call this Request or Response.

  • @electronicheartbreak.
    @electronicheartbreak. 7 днів тому

    I have some questions:
    1. Why do you add validation on the DTO, since input CAN and "should" be invalid? You also now have duplication in validation rules.
    2. Since you added validation on the DTO, you do not check the validity of the input by if Modelstate.IsValid. Why?

    • @juliocasal
      @juliocasal  7 днів тому

      The DTO is the input. What would you validate?

  • @pazzuto
    @pazzuto 6 місяців тому +2

    I'm surprise that for Post/Put/Delete, you did not use extensions. You could extend DTO just like entity with a method like ToEntity. That way, your mapping is all in the extensions class, and your endpoint doesn't need to know about this conversion.

  • @benchmarks1016
    @benchmarks1016 5 місяців тому +1

    upto 2:20

  • @somaticHuman
    @somaticHuman Рік тому +1

    I prefer to use user-defined explicit conversion operators inside DTOs, instead of extension methods...

    • @santhnu
      @santhnu Рік тому

      Would love to know how you do that? Would it offer any advantages/ease of use over extension methods? Thanks.

  • @agat366
    @agat366 Рік тому

    From my long experience, it’s quite inconvenient and time-consuming to define all the transformations. Imagine if you have several dozens of DTOs, also, it’s inconvenient as you have to make all the transformations changes manually after refactoring. I believe, more standard approach is auto-mapping. The only thing I would consider would be embedding AutoMapper into the AsDto extension methods.

    • @juliocasal
      @juliocasal  Рік тому +4

      Thanks, not a big fan of AutoMapper, and extension methods have been working great for me. But it's all a matter of personal taste!

    • @goqsane
      @goqsane 9 місяців тому

      Horrible advice. Don't follow.

    • @coding-esmaster3259
      @coding-esmaster3259 9 місяців тому

      Uff I would recommend not to use auto-mapping for projects does are not prototypes, auto-mapping becomes a headache when you change your models and you only get the errors in run-time instead of compilation and that's it is only example of another issues that you inherits by using AutoMapper.

    • @sagarmajumdar92
      @sagarmajumdar92 8 місяців тому

      ​​@@goqsane which one is the bad advice? What is shown in this video or using automapper

    • @goqsane
      @goqsane 8 місяців тому

      @@sagarmajumdar92using automapper. It'll bite you in the long run.