Skip to main content

Create a simple Android app that uses Encrypted Preferences with a Singleton architecture

Creating a simple Android app that uses Encrypted Preferences with a Singleton architecture involves several steps. Below is a guide to help you set up this app. We'll use Kotlin for this example.


Step 1: Set Up Your Android Project

  1. Open Android Studio and create a new project.
  2. Select an Empty Activity template.
  3. Name your project and choose Kotlin as the programming language.

Step 2: Add Dependencies

In your build.gradle (app level), add the dependencies for Encrypted Preferences:


dependencies {

    implementation 'androidx.security:security-crypto:1.1.0-alpha03'

    // Other dependencies

}

Step 3: Create the EncryptedPreferencesManager Singleton

Create a Kotlin file EncryptedPreferencesManager.kt in a suitable package (e.g., com.example.myapp).

package com.example.myapp

import android.content.Context

import androidx.security.crypto.EncryptedSharedPreferences

import androidx.security.crypto.MasterKeys


class EncryptedPreferencesManager private constructor(context: Context) {


    private val sharedPreferences = EncryptedSharedPreferences.create(

        "my_encrypted_prefs",

        MasterKeys.getOrCreate(MasterKeys.AES256_GCM_SPEC),

        context,

        EncryptedSharedPreferences.PrefKeyEncryptionScheme.AES256_SIV,

        EncryptedSharedPreferences.PrefValueEncryptionScheme.AES256_GCM

    )


    companion object {

        @Volatile private var INSTANCE: EncryptedPreferencesManager? = null


        fun getInstance(context: Context): EncryptedPreferencesManager {

            return INSTANCE ?: synchronized(this) {

                INSTANCE ?: EncryptedPreferencesManager(context).also { INSTANCE = it }

            }

        }

    }


    fun putString(key: String, value: String) {

        sharedPreferences.edit().putString(key, value).apply()

    }


    fun getString(key: String, defaultValue: String? = null): String? {

        return sharedPreferences.getString(key, defaultValue)

    }


    // Add other methods as needed

}


Step 4: Use EncryptedPreferencesManager in Your Activity

In your MainActivity.kt, you can use the EncryptedPreferencesManager to save and retrieve encrypted preferences.


package com.example.myapp


import android.os.Bundle

import androidx.appcompat.app.AppCompatActivity


class MainActivity : AppCompatActivity() {


    override fun onCreate(savedInstanceState: Bundle?) {

        super.onCreate(savedInstanceState)

        setContentView(R.layout.activity_main)


        val encryptedPreferences = EncryptedPreferencesManager.getInstance(this)


        // Save a value

        encryptedPreferences.putString("example_key", "example_value")


        // Retrieve a value

        val value = encryptedPreferences.getString("example_key")

        println("Retrieved value: $value")

    }

}




Comments

Popular posts from this blog

how to create chat gpt app in android with java code

  I'd be happy to provide you with some sample Java code for a chat GPT app in Android, however it is important to note that creating a complete and functional app requires a solid understanding of Android development, Java and OpenAI API, and also the code I provide here is just a skeleton or a sample of what it would look like in practice. You would need to import the OpenAI API library and configure it with your API key. Here is an example of how you might use the OpenAI Java client library to send user input to the GPT-3 model and receive the generated response: import openai.OpenAI; public class ChatGPT { private OpenAI openai; private String apiKey = "YOUR_API_KEY"; public ChatGPT() { openai = new OpenAI(apiKey); } public String generateResponse(String input) { String response = ""; try { response = openai.completions().create() .engine("text-davinci-002") ...

How to implement the Android ActionBar back button

Add this code in your on create activity Method  @Override protected void onCreate(Bundle savedInstanceState) { super .onCreate(savedInstanceState); setSupportActionBar(toolbar); getSupportActionBar().setDisplayHomeAsUpEnabled( true ); getSupportActionBar().setDisplayShowHomeEnabled( true ); } then call this method @Override public boolean onOptionsItemSelected(MenuItem item) { switch (item.getItemId()) { case android.R.id. home : finish(); return true ; default : return super .onOptionsItemSelected(item); } } this is default support action bar if you want your own then use own tool bar in your xml thanks
                             Top Troubleshooting in Android   If  you are android developer and you don't how to troubleshot your code so i am sharing with you some tips which will help you   ctrl + b for back trace your code it will redirect you to where you use of your code  ctrl+alt+ ← come back to privies use of code and if its not working then use alt + ← ctrl+ click it will redirect you to use code