9 Nisan 2019 Salı

Sql Server Database Language Change



-- Set to single-user mode
ALTER DATABASE yourdatabasename
SET SINGLE_USER WITH ROLLBACK IMMEDIATE
GO
  
-- change collation
ALTER DATABASE yourdatabasename  
COLLATE Turkish_CI_AS;  
GO  

-- Set to multi-user mode
ALTER DATABASE yourdatabasename
SET MULTI_USER WITH ROLLBACK IMMEDIATE;
GO  

--Verify the collation setting.  
SELECT name, collation_name  
FROM sys.databases  
WHERE name = yourdatabasename';  


9 Mart 2019 Cumartesi

Angular Routing Problem on Linux Host

If your angular application working well on localhost then does not work on linux host when redirecting any of existing page with returning 404 error. It means that you have missing routing configuration for routing.

To provide right configuration on linux apache server just put following code to .htAccess file of your angular application root folder and check the the magic :)

.htaccess file content should be as following:
RewriteEngine On # If an existing asset or directory is requested go to it as it is RewriteCond %{DOCUMENT_ROOT}%{REQUEST_URI} -f [OR] RewriteCond %{DOCUMENT_ROOT}%{REQUEST_URI} -d RewriteRule ^ - [L]
# If the requested resource doesn't exist, use index.html RewriteRule ^ /index.html


On the otherhand, If you deployed your app to another servers check the following solutions :

IIS Server on windows host , following webconfig rule can be help you to solve your redirection problem

web.config file content should be as following;

  1. <system.webServer>
  2. <rewrite>
  3. <rules>
  4. <rule name="Angular Routes" stopProcessing="true">
  5. <match url=".*" />
  6. <conditions logicalGrouping="MatchAll">
  7. <add input="{REQUEST_FILENAME}" matchType="IsFile" negate="true" />
  8. <add input="{REQUEST_FILENAME}" matchType="IsDirectory" negate="true" />
  9. </conditions>
  10. <action type="Rewrite" url="/index.html" />
  11. </rule>
  12. </rules>
  13. </rewrite>
  14. </system.webServer>

For more information about this issue, just check the offical page from this link : https://angular.io/guide/deployment

20 Şubat 2019 Çarşamba

How to set ASPNETCORE_ENVIRONMENT to Development Mode in Asp.Net Core MVC Application

Asp.Net MVC Core Application Development Mode 



When we deployed our application to the server and get any eror message then we won't be able to see details of message on previewed page. In this time we may convert our application to development mode via web.config.
In root folder of web.config file  we can add following  lines to child of AspNetCore element.

<environmentVariables>
<environmentVariable name="ASPNETCORE_ENVIRONMENT" value="Development" />
</environmentVariables>


Result view of config should be as following ;

<system.webServer>
<handlers>
<add name="aspNetCore" path="*" verb="*" modules="AspNetCoreModule" />
</handlers>
<aspNetCore processPath=".\CMSPortal.WebUI.exe" stdoutLogEnabled="false" >
<environmentVariables>
<environmentVariable name="ASPNETCORE_ENVIRONMENT" value="Development" />
</environmentVariables>
</aspNetCore>
</system.webServer>


Now we able to see all details of error messages :)

14 Şubat 2019 Perşembe

Running large .sql script via command line

Sometimes we need to run large sql script which has 1-10 gb size or something etc. then we won't be open this .sql file in sql, notepad, etc.

In this case, we need to run this command without any problem in easiest way, we can use commandline sqlcmd command to run our sql commands.


To do this operation, just follow few steps ;
 - Click Windows + R
 - type cmd and press enter to reach commandline
 - use  sqlcmd -S [servername] -d [databasename] -i [scriptfilename] command to run your file :)

Thats all.

In my scenario , I runned 8 GB .sql file with this method then it will completed successfuly without wasting memory or cpu while doing its job.

7 Şubat 2019 Perşembe

Mi Band 3 NFC ve Türkçe Diline Çevirme

Bu hafta eski kafa saat kullanımını bırakıp artık akıllı saatlere geçme kararı vermem ile birlikte. Yine de birkaç günde bir saat şarj etmek bana çok ters geldiği için bu dünyaya bir Xiaomi Mi Band bileklik ile girmek istedim.

Bunun üzerine kısa bir araştırma sonrası Xiaomi Mi Band 3 NFC modelini internetten satın aldım ve bugün kargo ile elime ulaştı. Öncesinde narin diye düşündüğüm için saati banta yerleştirme ve çıkarma kısımlarından biraz çekiniyodum fakat sonradan alışıp sert bir şekilde hızlıca çıkarıp takmaya başladım.


Kutu Açılışı
Öncelikle ilk geldiğinde cihazı bilgisayarınızdan yada bir adaptor yardımı ile şarj etmeniz gerekiyor. Ardından Android için PlayStore yada IOS için PlayStore a girip "Mi Fit" yazarak uygulamasını indirmeniz ve eşleştirmeniz gerekiyor.



Cihaz Eşleştirme
Bu işlem oldukça basit, telefonunuzdan uygulamayı açıp "Cihaz Ekle" kısmına bastığınızda bluetooth üzerinden cihazı arıyor ve cihazın butonuna basmanızı istiyor. Cihazın üzerindeki butona bastığınızda ise anında eşleştiriyor ve bir güncelleme var sie Mi Fit uygulaması üzerinden cihaza yükleme işlemini gerçekleştiriyor.

Temel Özellikler
 - Whatsapp ve diğer mesaj uygulamalarının bildirimlerini alıp okuyabiliyorsunuz
 - Saat Özelliği var :)
 - adım sayar, spor yapanlar için bazı ölçümler
 - Kartlarınızı kayıt edip nfc özelliği ile kullanabiliyorsunuz(Türkiye de destekleniyor mu emin değilim ama çin de yaygın olarak kullanılıyor)
 - Nabız Atış Ritmi Ölçümü
 - Adım Sayar ,
 - Mesafe Ölçer,
 - Yakılan Kalori Hesaplama,
 - Pil Durumu Gösterimi
 - Koşu Bandı ve Egzersiz Hesaplamaları
 - Kronometre,
 - Cihazımı Bul : Telefon acaip şekilde yüksek sesli bir alrm ile çalıyor, bulmamanız imkansız :)
 - Ekran Modları : 3 farklı ekran modu var seçip kullanabilirsiniz.
 - Hava Durumu : 3 günlük hava durumunu size gösteriyor

Yorumlarım
 Öncelikle cihaz fiyatına göre oldukça kullanışlı ve almayı düşünen olursa, düşünmeden alsın diyebilirim. Benim sevdiğim özellikleri telefona bakmama gerek kalmadan tüm gelen mesajları okuyabiliyor ve aramalarda titreşim özelliği ile telefonum sessizdeyken gelen aramaları kaçırmıyorum.Saat ve Hava durumu da günlük olarak bilgi edinmem için oldukça güzel özellikler. Temel olarak sadece bu özellikleri kullanmak ile birlikte arada nabız ölçümü de kendini kontrol altına almak için güzel bir özellik diyebilirim.

Türkçe Dile Çevirim
Cihazın NFC modeli standart olarak elime çince dilinde geldi, eğer telefonunuz ingilizce ise dil ingilizce oluyor ama bildirimlerdeki türkçe karakterler yine bozuk gelebiliyor. Ben o yüzden cihazı türkçeye çevirmeye çalıştım ve birkaç araştırma sonrasında aşağıdaki adımlardan problemi çözdüm

 - IOS : AmazTools uygulamasını indirin
 - https://geekdoing.com/forums/custom-firmwares.8/ linkinden cihazınızın güncel versiyonuna göre dil paketi indirebilirsiniz.
Ben elimdeki 1.7.0.4 versiyon için https://geekdoing.com/threads/firmwares-1-7-0-4-mi-band-3-nfc-spanish-turkish-thai.599/ linkinden türkçe desteğini indirdim telefonuma ve AmazTools uygulamasını açıp "Daha Fazla" ikonuna tıklayarak ek dosya yükle seçeneğinden ilgili dosyayı seçerek yükle ye tıkladım ve dil seçeneği türkçe oldu :)




24 Ocak 2019 Perşembe

Asp.Net Core Api - Swagger Kurulumu

Önceki yazılarımda Asp.Net Web Api Swagger kurulumundan bahsetmiştim. Şimdi sıra geldi .Net Core Api için swagger ı kolayca nasıl kurabiliriz ve apimizi dökümante edip kolayca testlerini gerçekleştirebiliriz kısmına.


Aşağıdaki adımları izleyerek .Net Core uygulamamıza swagger kurulumunu yapabiliriz.

1. Sırası ile ilgili menüyü izliyoruz ve Nuget Package Manager ı açıyoruz. Tools > NugetPackageManager > Manage Nuget Package Manager for Solution

2.Arama barına "Swashbuckle.AspNetCore" yazıp aratıyor ve ilk çıkan Nuget Package ı yüklüyoruz.

3. Yükleme tamamlandı şimdi sıra gerekli kodları Startup.cs dosyasına yerleştirip projemizde swagger ı çalışır hale getirme işleminde.

4. Startup.cs dosyamızı açıp aşağıda bold olarak belirtilen kısımlar kod dosyamıza ekleniyor.


       public void ConfigureServices(IServiceCollection services)
        {
            //Swagger döküman tanımını yapıyoruz.
            services.AddSwaggerGen(c =>
            {
                c.SwaggerDoc("v1", new Microsoft.OpenApi.Models.OpenApiInfo { Title = "WebApplication1", Version = "v1" });
            });

            services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_1);
        }


  // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
        public void Configure(IApplicationBuilder app, IHostingEnvironment env)
        {
            if (env.IsDevelopment())
            {
                app.UseDeveloperExceptionPage();
            }
            else
            {
                app.UseHsts();
            }

           //swagger kullanımı aktif ediliyor.
            app.UseSwagger();

           //swagger arayüz tanımı yapılıyor.
            app.UseSwaggerUI(c =>
            {
                c.SwaggerEndpoint("/swagger/v1/swagger.json", "Web Uygulamamızın Adı");
            });

            app.UseHttpsRedirection();
            app.UseMvc();
        }

İlgili kod dosyamızı son hali aşağıdaki görseldeki gibi olacak.



5. Artık projemiz swagger ile çalışmaya hazır. Projemizi çalıştırıyoruz ve localhost url mize /swagger yazıyoruz ve aşağıdaki gibi bir ekran karşımıza çıkıyor. Artık swagger alt yapısını kullanarak api mizi geliştirmeye devam edebiliriz.





17 Ocak 2019 Perşembe

How to determine computer disks are ssd or hdd ?

Today in my computer pc , I wonder that is my computer disks are ssd or not  ? Then just google it a while and learned that the following line of commands will show us disk partitions and disk types:

 - Open Windows PowerShell
 - run following command
Get-PhysicalDisk | select FriendlyName,BusType,MediaType
 - Then the following screen apeared;





 - According to informations above I have 2 partitions as 128 GB SSD and  hdd.