Excellent - Thank you. This will benefit many other viewers so I added it to the video. Just so you know, you need to start with "0:00 " to get UA-cam to pick it up and apply it to the video, so I added "0:00 Intro"
An interesting take on the subject. I like how these are more business level functionality focused rather than more developer-focused and granular like I have on my video on the subject. Nice stuff 🙏 PS: I historically had scaling issues with Seq and I can't really recommend it to anyone, at least not if you want long term retention (7-15 days+) in a high throughput environment
Your channel is very different, its very granular and low level examples of how to optimize code where as Tim Corey has a broader perspective and more of a overview. Both are are obviously great depending what you are out after.
I am a beginner to C# and I have found your every video really good, informative and helpful, So I wanna thank to you for your great contribution in the learning community, Thanks a lot sir!!!!!!!!!
Hey Tim, just got my first job as a Trainee Web Developer. My main language is Javascript(I've been a React/Nodejs developer for more than a year) but they asked me to learn C# at work. Your videos are helping a lot.
If you more interested in MassTransit you should check this playlist by the creator of the package himself: ua-cam.com/play/PLx8uyNNs1ri2MBx6BjPum5j9_MMdIfM9C.html
@@GeorgiMarokov I used an earlier version of MassTransit for an event driven system we had at my previous place of employment. We had upwards of 100,000,000+ messages a day going through the system. I would definitely use MassTransit again for a future project. As a matter of fact . . . now that I'm at a place that is Linux based, I look forward to trying out the latest MassTransit using .NET Core.
Yo. If I may ask a question about your choice, why did you choose C#, and have you considered Kotlin (since, AFAIU, it brings a lot of the good parts of C# to JVM world)?
@@MagicNumberArg I did not really have a choice. On my new job there is some C# software that i will have to maintain. So i started using C# for my own projects. I want to keep personal complexity as low as possible since i am just kind of starting out. But thanks for pointing that out. I might have a look at Kotlin :)
The "don't use real email addresses" part remembers me of a one-day-trail at a local web solutions company. I had to send some template mails, and i was new to javascript at that time. I ended up flooding the inbox of the company ceo with thousands of sample mails. Maybe i would've got the job if i flooded a testserver instead :D
Valuable lesson learned and Thank You for sharing. Hopefully others can learn from this. Don't use real "data", even if you think its secured and completely under your control. CEO's email address as test data did not work so well in this case. Avoid using real data (Actual account numbers, email addressed, credit card numbers, personal information, etc.) even when you are on a test server. I have seen too many "fails" where testing has impacted real world production environments.
The most classic example I can think of was from the 90s. One guy in a large Bank made a test email supposed to go to those with more than than a certain amount in the Account. He started them with Dear Rich Bastard. Unfortunately it went out to the actual customers :). He got fired for that. Not sure I would have been offended personally, kinda funny thing to get from your bank :).
Also if you need log viewer you can use my open source project at github.com/Analogy-LogViewer/Analogy.LogViewer it supports many log frameworks and even has real time server
I just wanted to take this moment to say Thank You!! Your content is amazing in fact i bought a few courses on your website. So far i have learned alot and i am not even halfway through. So thank you! Keep going your helping a lot of devs this way.
I would say Quartz is much better than Hangfire but it really depends on what you want to do. Quartz has more features and it's even easier with Crystal Quartz (Remote UI) to schedule jobs,maintain and re trigger them. Great video Tim.
I have a video request: Could you create a video where you explain Semaphores in detail? And maybe explain the differences between them, Mutex and Lock and also some best practices.
Really enjoying all of your videos! Great explanations and easy to follow along. This video is really helpful and I think important so we don't think to hard and overcomplicate things. Thank you for your work!
How is EPPlus better then OpenXMLand ExcelDataReader for reading and creating Excel spreadsheets? I spent a lot of time figuring out how to use those and find examples to create spreasheets with validation and import/export those spreadsheets for my business. I used ExcelDataReader because it was simple to read a spreadsheet created by someone else and skip the headers and columns that didn't match my criteria. I have something that works and unless it is WAY simple, I don't want to change anything at the moment, although I would like to upgrade my desktop application to .NET 5.0 and take advantage of new features. However, I'm stuck with some windows functionality in my library (yes probably a bad practice) to popup errors when trying to import spreadsheets and allow a retry.
Hope i'm not hijacking the thread, but would be curious if anyone knows of a good generalized text parser? And will add another note for useful library. This one handles command line parse, especially when it might get a little involved. Really handy, why so good? You define a class for various alternate command line settings. Worked on an app that might spin off one one of 12 other programs, and this helped. But still in a more traditional single/stand-alone app. Effectively you define a class, the library will inspect your define ProgramArgs class, and will handle the validation and error reporting of the message as defined. The library allows annotating your defined class with attributes to allow you to build up and customize it. And even better if parsed and no exception, immediately you have access to an instance the command argument class that match for the valid config. On larger applications have seen where the validation, error message and reporting starts getting rather disjoint at times. Not sure NuGet or GitHub is easier for all? Nugget: -> in VS CommandLineParser (in VS) Nuget/web -> www.nuget.org/packages/CommandLineParser/2.6.0 GitHub: => github.com/commandlineparser/commandline
@@marcusmaunula5018 I agree it's always best to just buy the license and at that point it will be great to consider devexpress or telerik and others too.
I'd love a video on creating PDF/printable reports on .NET 5 Razor/MVC state of the art. Everything I find seems to be old, ugly or generally both. I used Crystal Reports many years ago. That was quite powerful (although, again, ugly and not friendly to use). But I'm not sure what people are using nowadays to create some custom reports from a business web application.
Agreed! Like you, I looked around and was disappointed with the choices. Crystal isn't even an option anymore (except for people sticking to .NET Framework). SAP's (who owns Crystal) forum threads about it show that they have no clue what .NET Core is and say they will never support it. Our company is giving SSRS a try, and it seems decent so far. It lets you use a GUI tool to lay out the reports (taking that load off of the C# programmer), and then your C# code can grab the report via URL (and pass parameters and get back a PDF or whatever).
Great list. I tried a different library called ExcelMapper once epplus changes its licensing model. Really cool library to convert excel to pocos. Really made working with excelfiles a breeze.
@@andreasbramftl1106 thanks for the info. My company has an .NET Framework add in for MS Project that interacts with Excel. All of our clients have excel installed. Given that scenario, is there any benefit to using EPPlus over Interop?
Thank you Tim it's really helpful. Please can you create shay your ideas on how to add Layers into a project? What are the main common Layers ? What other Layers you may add it if needed? Thank you. And happy new year
I used Hangfire for job scheduling and it is easy to implement it. But only problem is to process parallel jobs we have to purchase the license Hangfire Ace packages
Thanks for a very interesting video. It would be great if you would teach more on Hangfire and share a little more details how you used it before. I would also really like a comparison between Hangfire and a Windows Service - when to use which and maybe to mix them. A .Net Core Windows Service is very easy to use as you already demonstrated in one of your videos if you need something to run every 5 minutes (or whatever interval) but what about once a day at a set hour or other variations? That cannot be done without some workarounds but maybe Hangfire is useful there???
I'd love a video or video-series about software-architecture and clean code. I've seen your videos about SOLID and DRY and Refactoring and many more that kinda talk about that topic. But as my applications are growing I still think they become a bit messy. Like where do i put all the Interfaces for dependency Injection. Where do i put all the Repositories for a repository pattern and so on. But also something like, how to manage overloads, or to many parameters for a method. Or I also struggle sometimes to find out which responsibility is something. Let's say for example a chess programm, who stores the position of a chess piece? The piece itself, the board, a tile on the board, or an extra gamestate class,...? And then further who would move those pieces..? I know there a no clear answers to those questions. But any tip or trick on those questions can be really helpfull.
An email library is what we use to send email from C# code. It still needs to connect to an email server (like Gmail) to send the actual email. Think of a C# email library as replacing the user typing out the message in an email client. C# does the typing and hits send. It relies on an email server to do the rest.
How to pop up selectable data rows from textbox i.e. a textbox in a form when space key pressed a pop up will appear from db and we can select the name of the firm that we want for transaction, on selection the selected value will go inside the textbox child ti parent .
In regards to your comments about logging, I have a routine that copies data from an Oracle server to an MS SQL Server. It massages some of the data. I like to log what I call exceptions. Data that doesn't fit the norm, but not NECESSARILY incorrect data. If a user calls and indicates that something looks amiss I can pull up that log to see if an exception existed and if so, what didn't it like about it? Do I read the logs? Not normally - only when warranted.
Just be careful there, because that logged data could be sensitive in nature. It is also not connected with the actual data, so you could run into legal issues if a user asks to be forgotten and you leave their information in the log files.
@@IAmTimCorey Thank you for the advice - and it's very solid advice. In this case the exceptions aren't tied to any personal data whatsoever and everything in this data that I'm retrieving is considered public information. I haven't implemented this logging as of yet, just something that I'm looking into. I need for staff to know what data that looked suspicious such as missing a property description. The program makes a safe assumption but it might not be the correct assumption. The owner of the data needs to be aware of the issue and decide whether it is a problem or not.
i would be glad if can make a video from a library who is working with the task scheduler system what you can write in your csharp application like the nuget packge task scheduler
Wow, the timing couldn't have been better! I was on the phone with another developer just last night, discussing a new project and was asking him if he knew of any libraries for reading / exporting excel files! Thanks for these resources
I'm new to C# and I'm enjoying your videos very much. I was reviewing this video on Libraries and I tried downloading one. The big question I have now is, where do you get documentation on what's in the library and how to use it. I did a lot of googling but didn't find any answer. Thanks for any help you can provide. My particular hurdle right now is CSV files.
Any time you have an application that wants to talk to another application in a disconnected manner. Microservices use this technique heavily but it doesn't have to be only them. Having this disconnect means that you can separate out parts of your application and update them without taking down the whole system or even losing anything while they are down.
@@IAmTimCorey Thanks for the very informative explanation, so compared to basic API communication in case using messages brokers we won't need to handle the acknowledgment part, am I right? Also, one more question related to Hangfire Can it be used to keep that data sync between applications? if not, what's the process to keep the data sync?
I used to rely on RDL/RDLC reports back in the framework days as well. I moved to DocX and EPPlus to create my Word and Excel-based reports, respectively. There aren't the visual cues you get from designing your report, but I found it easier to create my reports exactly like I want with the data I want.
Hi Tim, Thanks for sharing such a wonderful post once again. I was wandering whether there are some inbuilt tools to validate Excel data while importing to database. I want to validate my excel file such as columns datatype,sequence,number of columns etc and then store into DB and azure BLOB storage. Thanks Uttam tam,
Great tutorial really appreciated, it's good to know what other developers are using so you don't get lost into the myriads of tools while there are better tools out there. How would you suggest the use of Hangfire for task automation over let say creating your own windows service with another tool like topshelf which make it easier to create windows services, you have also discussed it in one of your videos? Can a windows service do all what can Hangfire do or hangfire is super easy to implement than a windows services? Email is one of things that are almost needed in business application, if you could discuss in one of your videos how to use these email application tools like MailKit (pop3/imap,smtp) , papercut the better way. Thanks a lot
Hangfire is about scheduling. Services are about running outside of a user's account. The two can be used together quite successfully. You can create a service that uses hangfire to schedule jobs to be run. By default, a service just runs all of the time. It is not set up to run things on a schedule (with retry, etc.) This is what hangfire adds.
Been using epplus for years. One thing u didn’t mention about it, is that it does not require excel or ms office to be installed on any server. Other libs require that 🙂
That's pretty much the biggest problem. And especially with these two requirements, unfortunately, it's usually the case that the ones you can use are usually quite expensive.
In asp.net core web api, is it possible to raise an event from an class, and listen to this event from another class and based on the event, do some task. How to achieve this? Also what is event-event handler-event bus? Very confusing. I was trying to decouple events in a standard .net library and was trying to move all events in one library. But got very confused.
You are right about EPP but what I don't like. Is when they start out as "free" libraries then change everything out of the blue. I'd much prefer if they were upfront with their long term plans from get go. Same problem with Identity Server 4 imho. But it is up to them of course. But then. MS makes Excel, they make VStudio. Would it be too much to ask for them to add something like this in the package? It's not like they have travel far to find the specs :).
Interesting - will look at EPPlus as it may put a lot of protections against the inconsistency of the Excel reference And I like the though of better logging And the email one Papercut makes sense for us.
@@IAmTimCorey I would like a video about the mailing libraries and the difference between the two and how to know which one is better for a specific project and I would like also a video about serialog and the Seq, and some videos about the steps to deploy an ASP.NET Web App on a physical server (with Docker and Sql Server ) and the best approach to secure it i know i am demanding a lot from you but you are so good at what you do and you are a gr8 developer
Hi Tim, I would like to know what is best for create and manage jobs? Azure web jobs vs Azure Functions vs HangFire? I appreciate it your comment, Thanks
Really nice picks of libraries :) When theres so much choice its hard to pick the best ones. It would be cool to find some newly emerged Libraries that are really cool but not a low of people have downloaded them yet
Do you think that is a good idea to use Hangfire instead to RabbitMQ in microservices, I know that they are different but at the same time very similar, because I think that Hangfire looks cool but at long term maybe is just a toy that is difficult to scale, what do you think?
These are two different technologies that do different things. Hangfire is about scheduling jobs to be run. RabbitMQ is about passing messages between applications. Both are great tools and both have their place. They just aren't interchangeable.
Hi Time. I stopped using hangfire cos I realized when it is used to fire a long running task, it would time out and call the task again causing duplicate calls.. So I fell back to using windows services for running repeated/scheduled task
So surprised that the Dapper, the AutoMapper, and the Nowtonsoft.JSON are not on the list. Maybe they are not just suggested but are necessary ones that no need to mention again. :)
I am a newby somewhat - I use windows task scheduler for my recurring jobs. Is hangfire basically the same or are there major differences I am not seeing
Hangfire will give you a much better picture of what has been done (great dashboard), it will have better reschedule/retry operations, and you can be more granular in how you schedule your tasks. Basically, you will have a lot more power. If you don't need the additional power, stick with what works.
It's a sad state of affairs when you have to explain, especially to developers, why it's fair to charge a fee to use someone's code, especially for commercial use. Software is expected to be free, while hardware isn't.
I don't remember how often I've had to explain to people that software is not cheap. Software is expensive. And the only reason people can get their (almost) free apps, webservices, etcetera, is because millions of development hours have gone into them over time... For applications that have millions of installations, that's fine and it can be spread over all users. For applications that are very specific for just one customer, not so much... I'm happy to pay for libraries, but it's sometimes hard to explain to custormers why they should. :)
@@teijeterbals1203 The big reason software perceived as free is because it's not a physical product. No matter ho much money was spent developing the software, the very fact that it isn't made up of atoms makes it difficult to accept its true value. In the old days when software was distributed on disks with a manual in a box, it had a higher value as the packaging made it at least something you can hold in your hands. Moreover, the fact that it costs nothing to deliver software increases this perception. If it costs nothing for you to upload it on a server for downloading, then it should cost nothing for someone to obtain a copy of it.
Hi Tim, which tool do you recommend for logs, Serilog with Seq or Azure application insights? I know those are different but for register and monitoring errors, which do you recommend?
Both, usually. Applicaiton Insights is good at giving you a big picture on what is going on in your application landscape. Logging is good for digging into specific problems.
My list is long and I make no promises that just because I put something on my list, that I will get to it. But still, its good to know its still of interest.
You might not have access to a service like that in whatever system you're on. And HangFire can do a bit more than run things on schedule. Can't speak for it in depth as I've only used it once a few years ago, but it's a great tool, for sure.
A service typically runs in the background on your computer. It might fire every minute and you can "schedule" it to do things. However, hangfire can do things like weekly, daily, etc. schedules, plus they can do chained tasks and more. You could write enough code to do what hangfire does, but it would take a lot of work.
We have switched from using EPPlus to ClosedXML, which is not having a dual license and having a good release cycle for updates also. github.com/ClosedXML/ClosedXML link provided for good measure.
hey Tim, thanks for all your works. New to your channel, i will defenetly stick around. Question about all commercial licences like the EPPlus 5 you presented us. If i'm a freelancer making programs for customers. If i (as an external developper) pay for the licence, are my customers in right to use the program even if they are not the licence owners?
Each company will specify what you can and cannot do with their software. In the case of EPPlus specifically, you can probably just purchase a license for yourself. Here is the FAQs that explain a bit better: www.epplussoftware.com/en/LicenseOverview/LicenseFAQ
Nowadays I am bound to code more in Javascript. But I still like watching your contents. I am following this channel since Tim Co retail manager project. Btw do you have any plans for Typescript tutorial? As it is also a programming language developed by Microsoft. It's easy to lure Javascript developers into Typescript. :)
2:38 SharpZipLib
4:02 FluentEmail
5:22 MailKit
6:14 Papercut SMTP
8:56 EPPlus
11:53 Hangfire
16:19 MassTransit
18:34 Polly
22:20 Serilog
26:05 Seq
Excellent - Thank you. This will benefit many other viewers so I added it to the video. Just so you know, you need to start with "0:00 " to get UA-cam to pick it up and apply it to the video, so I added "0:00 Intro"
Thanks.
An interesting take on the subject. I like how these are more business level functionality focused rather than more developer-focused and granular like I have on my video on the subject. Nice stuff 🙏
PS: I historically had scaling issues with Seq and I can't really recommend it to anyone, at least not if you want long term retention (7-15 days+) in a high throughput environment
Interesting. I'll check it out. Thanks for sharing.
Your channel is very different, its very granular and low level examples of how to optimize code where as Tim Corey has a broader perspective and more of a overview. Both are are obviously great depending what you are out after.
Thanks!
Thank you!
This is by far the greatest c# channel on youtube, great work! Thank you!
Glad you enjoy it!
I am a beginner to C# and I have found your every video really good, informative and helpful, So I wanna thank to you for your great contribution in the learning community, Thanks a lot sir!!!!!!!!!
You are welcome.
Hey Tim, just got my first job as a Trainee Web Developer. My main language is Javascript(I've been a React/Nodejs developer for more than a year) but they asked me to learn C# at work. Your videos are helping a lot.
That is awesome!
Would love to see a video about MassTransit
Also Hangfire :)
If you more interested in MassTransit you should check this playlist by the creator of the package himself:
ua-cam.com/play/PLx8uyNNs1ri2MBx6BjPum5j9_MMdIfM9C.html
I appreciate the suggestion and added it to my list.
@@GeorgiMarokov I used an earlier version of MassTransit for an event driven system we had at my previous place of employment. We had upwards of 100,000,000+ messages a day going through the system. I would definitely use MassTransit again for a future project. As a matter of fact . . . now that I'm at a place that is Linux based, I look forward to trying out the latest MassTransit using .NET Core.
i got into software development by learning java first. just recently switched to c# and i highly appreciate what you are doing here. keep it up!
Yo. If I may ask a question about your choice, why did you choose C#, and have you considered Kotlin (since, AFAIU, it brings a lot of the good parts of C# to JVM world)?
@@MagicNumberArg I did not really have a choice. On my new job there is some C# software that i will have to maintain. So i started using C# for my own projects. I want to keep personal complexity as low as possible since i am just kind of starting out. But thanks for pointing that out. I might have a look at Kotlin :)
Welcome to our world of C#! I'm glad my resources are of help.
The "don't use real email addresses" part remembers me of a one-day-trail at a local web solutions company.
I had to send some template mails, and i was new to javascript at that time. I ended up flooding the inbox of the company ceo with thousands of sample mails. Maybe i would've got the job if i flooded a testserver instead :D
Valuable lesson learned and Thank You for sharing. Hopefully others can learn from this. Don't use real "data", even if you think its secured and completely under your control. CEO's email address as test data did not work so well in this case. Avoid using real data (Actual account numbers, email addressed, credit card numbers, personal information, etc.) even when you are on a test server. I have seen too many "fails" where testing has impacted real world production environments.
@@IAmTimCorey
So what you're saying is use common sense😊
The most classic example I can think of was from the 90s. One guy in a large Bank made a test email supposed to go to those with more than than a certain amount in the Account. He started them with Dear Rich Bastard. Unfortunately it went out to the actual customers :). He got fired for that. Not sure I would have been offended personally, kinda funny thing to get from your bank :).
@@Dave-nv5rv But the sense is not common with everybody!
@@Dave-nv5rv common sense is neither sensical nor common
This video was perfectly timed because I was just starting to look for a logging solution. Thanks for the great info.
Glad it was helpful!
Same 👋
Also if you need log viewer you can use my open source project at github.com/Analogy-LogViewer/Analogy.LogViewer
it supports many log frameworks and even has real time server
I just wanted to take this moment to say Thank You!!
Your content is amazing in fact i bought a few courses on your website.
So far i have learned alot and i am not even halfway through.
So thank you! Keep going your helping a lot of devs this way.
Awesome, thank you!
Been following this guys videos for years now, absolute god send!
I'm glad my content has been helpful.
Very informative video, appreciate it. It would be good idea to do such videos from time to time.
Glad you liked it!
I would say Quartz is much better than Hangfire but it really depends on what you want to do. Quartz has more features and it's even easier with Crystal Quartz (Remote UI) to schedule jobs,maintain and re trigger them. Great video Tim.
Fair enough! Thanks for sharing your perspective.
I have a video request: Could you create a video where you explain Semaphores in detail? And maybe explain the differences between them, Mutex and Lock and also some best practices.
I appreciate the suggestion and added it to my list.
This was very helpful and put several tools on my radar. THANK YOU!!
You are welcome.
Really enjoying all of your videos! Great explanations and easy to follow along. This video is really helpful and I think important so we don't think to hard and overcomplicate things. Thank you for your work!
Glad it was helpful!
Thank you Tim, You are Time Saver.
Glad to help
Tim-e saver
Hi Tim. Some of the alerting you mentioned for Seq can also be done with Grafana and App metrics.
Thanks for sharing.
How is EPPlus better then OpenXMLand ExcelDataReader for reading and creating Excel spreadsheets? I spent a lot of time figuring out how to use those and find examples to create spreasheets with validation and import/export those spreadsheets for my business. I used ExcelDataReader because it was simple to read a spreadsheet created by someone else and skip the headers and columns that didn't match my criteria. I have something that works and unless it is WAY simple, I don't want to change anything at the moment, although I would like to upgrade my desktop application to .NET 5.0 and take advantage of new features. However, I'm stuck with some windows functionality in my library (yes probably a bad practice) to popup errors when trying to import spreadsheets and allow a retry.
Hope i'm not hijacking the thread, but would be curious if anyone knows of a good generalized text parser? And will add another note for useful library. This one handles command line parse, especially when it might get a little involved. Really handy, why so good? You define a class for various alternate command line settings. Worked on an app that might spin off one one of 12 other programs, and this helped. But still in a more traditional single/stand-alone app.
Effectively you define a class, the library will inspect your define ProgramArgs class, and will handle the validation and error reporting of the message as defined. The library allows annotating your defined class with attributes to allow you to build up and customize it. And even better if parsed and no exception, immediately you have access to an instance the command argument class that match for the valid config. On larger applications have seen where the validation, error message and reporting starts getting rather disjoint at times.
Not sure NuGet or GitHub is easier for all?
Nugget: ->
in VS CommandLineParser (in VS)
Nuget/web -> www.nuget.org/packages/CommandLineParser/2.6.0
GitHub: => github.com/commandlineparser/commandline
I was just starting to add e-mail and logging to my project when I saw this video. Thank you!
Glad it was helpful!
Thank you so much, I didn't know about those libraries 😊 Love your channel, keep it up!
Thank you! Will do!
Several of these will be very useful to me. Thanks Tim.
You bet
Another good one to look at: PowerAssert - when the unit test fails it shows you exactly why straight away.
"Never wanna send out an email to real people for test purpose". Yes, you got me. But that's fun.
Testing fails - now there is a fun (and scary) topic.
Email no, SMS yes :)
never send advertising emails to clients after midnight, its not fun at all, you can ask my boss 😅
How else would you know they are real?
Polly looks really interesting. I have been planning on using it in my next project
Go for it!
Hope to see video about SignalR. I am trying to get grasp of it but most of the videos I saw doesn't really explain it that well..
That's high on the priority list.
@@IAmTimCorey cool!! Can't wait to watch and learn! 😊
*EPPlus is free for commercial applications below v 5.0
Thanks for the tip.
Syncfusion also has a generous free tier for small operations. It gets some tasks done rather quickly.
@@bangonkali You have to keep track of the revenue of your customers though. Max 1m USD per year. Might just be easier to buy a package.
@@marcusmaunula5018 I agree it's always best to just buy the license and at that point it will be great to consider devexpress or telerik and others too.
@@bangonkali I am a little tempted by the SF Blazor Package. You have any experience with it?
Thanks for the great libs! I would like to see more videos like this in the future :)
I noted your recommendation and have added to my list, thanks.
AWESOME video. Thanks for the good pointers to interesting libraries.
👍
Thank you!
Happy new year Tim Corey! your video help me a lot
Happy new year!
I'd love a video on creating PDF/printable reports on .NET 5 Razor/MVC state of the art. Everything I find seems to be old, ugly or generally both. I used Crystal Reports many years ago. That was quite powerful (although, again, ugly and not friendly to use). But I'm not sure what people are using nowadays to create some custom reports from a business web application.
Agreed! Like you, I looked around and was disappointed with the choices. Crystal isn't even an option anymore (except for people sticking to .NET Framework). SAP's (who owns Crystal) forum threads about it show that they have no clue what .NET Core is and say they will never support it. Our company is giving SSRS a try, and it seems decent so far. It lets you use a GUI tool to lay out the reports (taking that load off of the C# programmer), and then your C# code can grab the report via URL (and pass parameters and get back a PDF or whatever).
Topic suggestion noted and have added to my list, thanks.
Great list. I tried a different library called ExcelMapper once epplus changes its licensing model. Really cool library to convert excel to pocos. Really made working with excelfiles a breeze.
Thanks for the tip.
i've been using EPPlus for years. It's amazing!
It really is.
I love it!, Just added a pair library. Thanks for sharing it.
Thanks for commenting.
You are welcome.
Excellent Tim. Thanks a lot.
You are welcome.
wow ... i would love to see a video about Hangfire ... it would be fun
We appreciate the suggestion and I have added it to Tim's list.
Tim, I’d love to see more EPPlus and how it’s better than just adding a reference to Microsoft.Office.Interop.Excel and working with that library.
Topic suggestion noted and have added to my list, thanks.
@@andreasbramftl1106 thanks for the info. My company has an .NET Framework add in for MS Project that interacts with Excel. All of our clients have excel installed. Given that scenario, is there any benefit to using EPPlus over Interop?
Can you please make a video on Mass Transit and Azure Service Bus?
Added to my list, will see if/when I can get to it.
Happy New Year, Tim!
Happy new year!
Super useful video, thank you Tim
Glad it was helpful!
I used Polly and hangfire. And this libraries is great. Thanks safe this video for feature
Thanks for sharing
Thank you Tim it's really helpful.
Please can you create shay your ideas on how to add Layers into a project? What are the main common Layers ? What other Layers you may add it if needed?
Thank you. And happy new year
Happy new Year Tim, I want to thanks you for all your videos that really helped me a lot. Do you have a plan this year to start a Xamarin course?
Not this year because of the changing coming with .NET 6.
@@IAmTimCorey Thanks Tim
EPPlus - Life saver working with Excelsheets
Thanks for sharing
Very nice video. Interestingly all these problems relate to me and yet I do not have a perfect way to deal with them. Well not anymore...
I am glad it was helpful.
I used Hangfire for job scheduling and it is easy to implement it. But only problem is to process parallel jobs we have to purchase the license Hangfire Ace packages
Yep, but that's how they pay for their development costs. The developers have to eat, and that's the way they do it.
Thanks for a very interesting video. It would be great if you would teach more on Hangfire and share a little more details how you used it before. I would also really like a comparison between Hangfire and a Windows Service - when to use which and maybe to mix them. A .Net Core Windows Service is very easy to use as you already demonstrated in one of your videos if you need something to run every 5 minutes (or whatever interval) but what about once a day at a set hour or other variations? That cannot be done without some workarounds but maybe Hangfire is useful there???
Thanks for the suggestion. I have added it to the list of possible future topics.
I'd love a video or video-series about software-architecture and clean code. I've seen your videos about SOLID and DRY and Refactoring and many more that kinda talk about that topic. But as my applications are growing I still think they become a bit messy. Like where do i put all the Interfaces for dependency Injection. Where do i put all the Repositories for a repository pattern and so on. But also something like, how to manage overloads, or to many parameters for a method. Or I also struggle sometimes to find out which responsibility is something. Let's say for example a chess programm, who stores the position of a chess piece? The piece itself, the board, a tile on the board, or an extra gamestate class,...? And then further who would move those pieces..? I know there a no clear answers to those questions. But any tip or trick on those questions can be really helpfull.
I appreciate the suggestion and added it to my list.
Beginner here.
We would we need a email library. What' s the benefit compared to something easy and fast like gmail?
An email library is what we use to send email from C# code. It still needs to connect to an email server (like Gmail) to send the actual email. Think of a C# email library as replacing the user typing out the message in an email client. C# does the typing and hits send. It relies on an email server to do the rest.
How to pop up selectable data rows from textbox i.e. a textbox in a form when space key pressed a pop up will appear from db and we can select the name of the firm that we want for transaction, on selection the selected value will go inside the textbox child ti parent .
In regards to your comments about logging, I have a routine that copies data from an Oracle server to an MS SQL Server. It massages some of the data. I like to log what I call exceptions. Data that doesn't fit the norm, but not NECESSARILY incorrect data. If a user calls and indicates that something looks amiss I can pull up that log to see if an exception existed and if so, what didn't it like about it? Do I read the logs? Not normally - only when warranted.
Just be careful there, because that logged data could be sensitive in nature. It is also not connected with the actual data, so you could run into legal issues if a user asks to be forgotten and you leave their information in the log files.
@@IAmTimCorey Thank you for the advice - and it's very solid advice. In this case the exceptions aren't tied to any personal data whatsoever and everything in this data that I'm retrieving is considered public information. I haven't implemented this logging as of yet, just something that I'm looking into. I need for staff to know what data that looked suspicious such as missing a property description. The program makes a safe assumption but it might not be the correct assumption. The owner of the data needs to be aware of the issue and decide whether it is a problem or not.
i would be glad if can make a video from a library who is working with the task scheduler system what you can write in your csharp application like the nuget packge task scheduler
Thanks for the suggestion. Please add it to the list on the suggestion site so others can vote on it as well: suggestions.iamtimcorey.com/
Wow, the timing couldn't have been better!
I was on the phone with another developer just last night, discussing a new project and was asking him if he knew of any libraries for reading / exporting excel files!
Thanks for these resources
Great! You are welcome.
Any thoughts on Syncfusion products?
I'm new to C# and I'm enjoying your videos very much. I was reviewing this video on Libraries and I tried downloading one. The big question I have now is, where do you get documentation on what's in the library and how to use it. I did a lot of googling but didn't find any answer. Thanks for any help you can provide. My particular hurdle right now is CSV files.
Great heads-up on the EPPlus licensing change. Gotta let my team know.
Glad it helped.
I use most of those libraries. They are very useful indeed!
Thanks for sharing.
What are the use cases that required using messages brokers such as RabbitMQ, Azure Bus.. etc?
Any time you have an application that wants to talk to another application in a disconnected manner. Microservices use this technique heavily but it doesn't have to be only them. Having this disconnect means that you can separate out parts of your application and update them without taking down the whole system or even losing anything while they are down.
@@IAmTimCorey Thanks for the very informative explanation, so compared to basic API communication in case using messages brokers we won't need to handle the acknowledgment part, am I right?
Also, one more question related to Hangfire
Can it be used to keep that data sync between applications? if not, what's the process to keep the data sync?
Hi Mr.Tim,
Do you recommend a library to preview or export RDL/RDLC reports because ReportViewer is not supported on .Net Core yet?
Ff
Not a free one, no.
@@IAmTimCorey Please what do you recommend instead?
I used to rely on RDL/RDLC reports back in the framework days as well. I moved to DocX and EPPlus to create my Word and Excel-based reports, respectively. There aren't the visual cues you get from designing your report, but I found it easier to create my reports exactly like I want with the data I want.
Hi Tim,
Thanks for sharing such a wonderful post once again. I was wandering whether there are some inbuilt tools to validate Excel data while importing to database. I want to validate my excel file such as columns datatype,sequence,number of columns etc and then store into DB and azure BLOB storage.
Thanks
Uttam tam,
Another great video! Thanks Again!
You are welcome.
Great tutorial really appreciated, it's good to know what other developers are using so you don't get lost into the myriads of tools while there are better tools out there.
How would you suggest the use of Hangfire for task automation over let say creating your own windows service with another tool like topshelf which make it easier to create windows services, you have also discussed it in one of your videos? Can a windows service do all what can Hangfire do or hangfire is super easy to implement than a windows services?
Email is one of things that are almost needed in business application, if you could discuss in one of your videos how to use these email application tools like MailKit (pop3/imap,smtp) , papercut the better way.
Thanks a lot
Hangfire is about scheduling. Services are about running outside of a user's account. The two can be used together quite successfully. You can create a service that uses hangfire to schedule jobs to be run. By default, a service just runs all of the time. It is not set up to run things on a schedule (with retry, etc.) This is what hangfire adds.
@@IAmTimCorey thanks
That is superb, I'm enraptured by the content. #Fabulous 👌
Great!
Been using epplus for years. One thing u didn’t mention about it, is that it does not require excel or ms office to be installed on any server. Other libs require that 🙂
Very true. That's a great feature.
Great video, well done
Thank you very much!
Man!! That was awesome
Glad you liked it!
Tim you are a legend ,
Thanks for sharing.
Thanks for the Excellent video... Please let me know a library to extract text, images, table data, text from OCR scanned images from a PDF.
I don't have one to share. Maybe someone else does.
How do you handle PDF Creation? In business software producing PDF Files is as crucial as Excel File manipulation.
Check PDFSharp or iTextSharp
That's pretty much the biggest problem. And especially with these two requirements, unfortunately, it's usually the case that the ones you can use are usually quite expensive.
You can try using inkscape as well for pdf creation it's free
@@SachinDiwate via C# really ????
@@SachinDiwate That's not a solution.
In asp.net core web api, is it possible to raise an event from an class, and listen to this event from another class and based on the event, do some task. How to achieve this? Also what is event-event handler-event bus? Very confusing. I was trying to decouple events in a standard .net library and was trying to move all events in one library. But got very confused.
You are right about EPP but what I don't like. Is when they start out as "free" libraries then change everything out of the blue. I'd much prefer if they were upfront with their long term plans from get go. Same problem with Identity Server 4 imho. But it is up to them of course. But then. MS makes Excel, they make VStudio. Would it be too much to ask for them to add something like this in the package? It's not like they have travel far to find the specs :).
I agree it would be good to know, but I don't think they always know at the start.
Interesting - will look at EPPlus as it may put a lot of protections against the inconsistency of the Excel reference
And I like the though of better logging
And the email one Papercut makes sense for us.
Excellent! Glad you can use those.
nice libs. will you make videos later on how to use them and/or integrate them in new projects or existing ones
It depends which ones people want to see more info on.
@@IAmTimCorey I would like a video about the mailing libraries and the difference between the two and how to know which one is better for a specific project and I would like also a video about serialog and the Seq,
and some videos about the steps to deploy an ASP.NET Web App on a physical server (with Docker and Sql Server ) and the best approach to secure it
i know i am demanding a lot from you but you are so good at what you do and you are a gr8 developer
Hangfire would be awesome to see...
Thanks for the suggestion.
Hi Tim, I would like to know what is best for create and manage jobs?
Azure web jobs vs Azure Functions vs HangFire?
I appreciate it your comment,
Thanks
It depends on the circumstances. You can leave a suggestion for this to be a future video at suggestions.iamtimcorey.com
Really nice picks of libraries :) When theres so much choice its hard to pick the best ones. It would be cool to find some newly emerged Libraries that are really cool but not a low of people have downloaded them yet
If you find those "emerged Libraries that are really cool", please share them here!
Thanks for the video!
You're welcome!
Thanks for sharing this, it helps a lot :)
Glad it was helpful!
Thank you, Tim
Thank you for watching
Hey Tim, I am in search of a library which can give difference (of values) between two objects. Can you please recommend some?
I'm sorry, I'm not sure what you mean.
Do you think that is a good idea to use Hangfire instead to RabbitMQ in microservices, I know that they are different but at the same time very similar, because I think that Hangfire looks cool but at long term maybe is just a toy that is difficult to scale, what do you think?
These are two different technologies that do different things. Hangfire is about scheduling jobs to be run. RabbitMQ is about passing messages between applications. Both are great tools and both have their place. They just aren't interchangeable.
With Unity moving to data driven design I wonder if it'll still be possible to plug OOP libraries in with it.
Not sure.
Hi Time. I stopped using hangfire cos I realized when it is used to fire a long running task, it would time out and call the task again causing duplicate calls.. So I fell back to using windows services for running repeated/scheduled task
Interesting. You should be able to tweak your setup to fix that. Are you making the calls async?
So surprised that the Dapper, the AutoMapper, and the Nowtonsoft.JSON are not on the list. Maybe they are not just suggested but are necessary ones that no need to mention again. :)
Everyone has their favorites!
I am a newby somewhat - I use windows task scheduler for my recurring jobs. Is hangfire basically the same or are there major differences I am not seeing
Hangfire will give you a much better picture of what has been done (great dashboard), it will have better reschedule/retry operations, and you can be more granular in how you schedule your tasks. Basically, you will have a lot more power. If you don't need the additional power, stick with what works.
It's a sad state of affairs when you have to explain, especially to developers, why it's fair to charge a fee to use someone's code, especially for commercial use. Software is expected to be free, while hardware isn't.
Not everyone has gained that real world experience. That is why we need to share it.
I don't remember how often I've had to explain to people that software is not cheap. Software is expensive. And the only reason people can get their (almost) free apps, webservices, etcetera, is because millions of development hours have gone into them over time...
For applications that have millions of installations, that's fine and it can be spread over all users.
For applications that are very specific for just one customer, not so much...
I'm happy to pay for libraries, but it's sometimes hard to explain to custormers why they should. :)
@@teijeterbals1203 The big reason software perceived as free is because it's not a physical product. No matter ho much money was spent developing the software, the very fact that it isn't made up of atoms makes it difficult to accept its true value. In the old days when software was distributed on disks with a manual in a box, it had a higher value as the packaging made it at least something you can hold in your hands.
Moreover, the fact that it costs nothing to deliver software increases this perception. If it costs nothing for you to upload it on a server for downloading, then it should cost nothing for someone to obtain a copy of it.
Great Tim 💪
Thanks
Hi Tim, which tool do you recommend for logs, Serilog with Seq or Azure application insights?
I know those are different but for register and monitoring errors, which do you recommend?
Both, usually. Applicaiton Insights is good at giving you a big picture on what is going on in your application landscape. Logging is good for digging into specific problems.
Still hoping for a special session on Cake. Would pay for such a course in fact.
My list is long and I make no promises that just because I put something on my list, that I will get to it. But still, its good to know its still of interest.
Love Hangfire.
Thanks for sharing
Hi Tim, I didn't really understand the difference between HangFire to a serivce that is automaticly run on schedule...
You might not have access to a service like that in whatever system you're on. And HangFire can do a bit more than run things on schedule. Can't speak for it in depth as I've only used it once a few years ago, but it's a great tool, for sure.
A service typically runs in the background on your computer. It might fire every minute and you can "schedule" it to do things. However, hangfire can do things like weekly, daily, etc. schedules, plus they can do chained tasks and more. You could write enough code to do what hangfire does, but it would take a lot of work.
The least I can say is THANK YOU
You're welcome
We have switched from using EPPlus to ClosedXML, which is not having a dual license and having a good release cycle for updates also.
github.com/ClosedXML/ClosedXML link provided for good measure.
Thanks for sharing.
hey Tim, thanks for all your works. New to your channel, i will defenetly stick around. Question about all commercial licences like the EPPlus 5 you presented us. If i'm a freelancer making programs for customers. If i (as an external developper) pay for the licence, are my customers in right to use the program even if they are not the licence owners?
Each company will specify what you can and cannot do with their software. In the case of EPPlus specifically, you can probably just purchase a license for yourself. Here is the FAQs that explain a bit better: www.epplussoftware.com/en/LicenseOverview/LicenseFAQ
Tim, do you have any videos on c# and data oriented design?
Nope.
FileHelpers is my all time favorite
Great!
Any thoughts on just using OleDb to read excel files (with MS Access Database Engine)?
That requires Excel to be installed on the server. That's not a great situation (plus OleDb is messy).
Nowadays I am bound to code more in Javascript. But I still like watching your contents. I am following this channel since Tim Co retail manager project. Btw do you have any plans for Typescript tutorial? As it is also a programming language developed by Microsoft. It's easy to lure Javascript developers into Typescript. :)
I appreciate the suggestion and added it to my list.