We've detected that you're using an ad content blocking browser plug-in or feature. Ads provide a critical source of revenue to the continued operation of Silicon Investor.  We ask that you disable ad blocking while on Silicon Investor in the best interests of our community.  If you are not using an ad blocker but are still receiving this message, make sure your browser's tracking protection is set to the 'standard' level.

   Technology StocksSmartphones, Tablets, Wearables and Gadgets

Previous 10 Next 10 
To: radkapital who wrote (3014)2/28/2021 6:54:08 PM
From: Latest Review
   of 3027
Excellent Article, yes xiaomi is Biggest selling phone in India due to socio economic Status of majority of Indians

Share RecommendKeepReplyMark as Last ReadRead Replies (1)

To: Latest Review who wrote (3015)3/2/2021 10:09:18 AM
From: FJB
   of 3027

Are Xiaomi browsers spyware? Yes, they are…
Wladimir Palant

In case you missed it, there was a Forbes article on Mi Browser Pro and Mint Browser which are preinstalled on Xiaomi phones. The article accuses Xiaomi of exfiltrating a history of all visited websites. Xiaomi on the other hand accuses Forbes of misrepresenting the facts. They claim that the data collection is following best practices, the data itself being aggregated and anonymized, without any connection to user’s identity.

TL;DR: It is really that bad, and even worse actually.

If you’ve been following my blog for a while, you might find this argumentation familiar. It’s almost identical to Avast’s communication after they were found spying on the users and browser vendors pulled their extensions from add-on stores. In the end I was given proof that their data anonymization attempts were only moderately successful if you allow me this understatement.

Given that neither the Forbes article nor the security researchers involved seem to provide any technical details, I wanted to take a look for myself. I decompiled Mint Browser 3.4.0 and looked for clues. This isn’t the latest version, just in case Xiaomi already modified to code in reaction to the Forbes article. Update (2020-05-08): If you don’t need the technical explanation, the newer article gives an overview of the issue.

Disclaimer: I think that this is the first time I analyzed a larger Android application, so please be patient with me. I might have misinterpreted one thing or another, even though the big picture seems to be clear. Also, my conclusions are based exclusively on code analysis, I’ve never seen this browser in action.


The general analytics setup The Forbes article explains that the data is being transmitted to a Sensors Analytics backend. The Xiaomi article then provides the important clue: is the host name of this backend. They then go on explaining how it’s a server that Xiaomi owns rather than a third party. But they are merely trying to distract us: if sensitive data from my browser is being sent to this server, why would I care who owns it?

We find this server name mentioned in the class miui.globalbrowser.common_business.g.i (yes, some package and class names are mangled). It’s used in some initialization code:

final StringBuilder sb = new StringBuilder(); sb.append(""); sb.append(A.e); a = sb.toString();
Looking up A.e, it turns out to be a country code. So the i.a static member here ends up holding the endpoint URL with the user’s country code filled in. And it is being used in the class’ initialization function:

public void a(final Context c) { SensorsDataAPI.sharedInstance(this.c = c, i.a, this.d); SensorsDataAPI.sharedInstance().identify(com.xiaomi.mistatistic.sdk.e.a(this.c)); this.c(); this.d(); this.e(); this.b(); }
The Sensors Analytics API is public, so we can look up the SensorsDataAPI class and learn that the first sharedInstance() call creates an instance and sets its server URL. The next line calls identify() setting an “anonymous ID” for this instance which will be sent along with every data point, more on that later.

The call to this.c() is also worth noting as this will set a bunch of additional properties to be sent with each request:

public void c() { final JSONObject jsonObject = new JSONObject(); jsonObject.put("uuid", (Object)com.xiaomi.mistatistic.sdk.e.a(this.c)); int n; if (H.f(miui.globalbrowser.common.a.a())) { n = 1; } else { n = 0; } jsonObject.put("internet_status", n); jsonObject.put("platform", (Object)"AndroidApp"); jsonObject.put("miui_version", (Object)Build$VERSION.INCREMENTAL); final String e = A.e; a(e); jsonObject.put("miui_region", (Object)e); jsonObject.put("system_language", (Object)A.b); SensorsDataAPI.sharedInstance(this.c).registerSuperProperties(jsonObject); }
There we have the same “anonymous ID” sent as uuid parameter, just in case. In addition, the usual version, region, language data is being sent.

For me, it wasn’t entirely trivial to figure out where this class is being initialized from. Turns out, from class miui.globalbrowser.common_business.g.b:

public static void a(final String s, final Map<String, String> map) { a(s, map, true); } public static void a(final String s, final Map<String, String> map, final boolean b) { if (b) { i.a().a(s, map); } miui.globalbrowser.common_business.g.d.a().a(s, map); }
So the miui.globalbrowser.common_business.g.b.a() call will set the third parameter to true by default. This call accesses a singleton miui.globalbrowser.common_business.g.i instance (will be created if it doesn’t exist) and makes it actually track an event (s is the event name here and map are the parameters being sent in addition to the default ones). The additional miui.globalbrowser.common_business.g.d.a() call triggers their MiStatistics analytics framework which I didn’t investigate.

And that’s it. We now have to find where in the code miui.globalbrowser.common_business.g.b class is used and what data it receives. All that data will be sent to Sensors Analytics backend regularly.

How anonymous is that ID? Looking up com.xiaomi.mistatistic.sdk.e.a() eventually turns up ID generation code very close to the one cited in the Xiaomi blog post:

public static String d(final Context context) { if (!TextUtils.isEmpty((CharSequence)y.g)) { return y.g; } final long currentTimeMillis = System.currentTimeMillis(); final String a = L.a(context, "anonymous_id", ""); final long a2 = L.a(context, "aigt", 0L); final long a3 = L.a(context, "anonymous_ei", 7776000000L); if (!TextUtils.isEmpty((CharSequence)a) && currentTimeMillis - a2 < a3) { y.g = a; } else { L.b(context, "anonymous_id", y.g = UUID.randomUUID().toString()); } L.c(context, "aigt", currentTimeMillis); return y.g; }
The L.a() call is retrieving a value from context.getSharedPreferences() with fallback. L.b() and L.c() calls will store a value there. So Xiaomi is trying to tell us: “Look, the ID is randomly generated, without any relation to the user. And it is renewed every 90 days!”

Now 90 days are a rather long time interval even for a randomly generated ID. With enough data points it should be easy to deduce the user’s identity from it. But there is another catch. See that aigt preference? What is its value?

The intention here seems to be that aigt is the timestamp when the ID was generated. So if that timestamp deviates from current time by more than 7776000000 milliseconds (90 days) a new ID is going to be generated. However, this implementation is buggy, it will update aigt on every call rather than only when a new ID is generated. So the only scenario where a new ID will be generated is: this method wasn’t called for 90 days, meaning that the browser wasn’t started for 90 days. And that’s rather unlikely, so one has to consider this ID permanent.

And if this weren’t enough, there is another catch. If you look at the SensorsDataAPI class again, you will see that the “anonymous ID” is merely a fallback when a login ID isn’t available. And what is the login ID here? We’ll find it being set in the miui.globalbrowser.common_business.g.i class:

public void b() { final Account a = miui.globalbrowser.common.c.b.a(this.c); if (a != null && !TextUtils.isEmpty((CharSequence) { SensorsDataAPI.sharedInstance().login(; } }
That’s exactly what it looks like: a Xiaomi account ID. So if the user is logged into the browser, the tracking data will be connected to their Xiaomi account. And that one is linked to the user’s email address at the very least, probably to other identifying parameters as well.

What is being collected? As mentioned above, we need to look at the places where miui.globalbrowser.common_business.g.b class methods are called. And very often these are quite typical for product analytics, for example:

final HashMap<String, String> hashMap = new HashMap<String, String>(); if (ex.getCause() != null) { hashMap.put("cause", ex.getCause().toString()); } miui.globalbrowser.common_business.g.b.a("rv_crashed", hashMap);
So there was a crash and the vendor is notified about the issue. Elsewhere the data indicates that a particular element of the user interface was opened, also very useful information to improve the product. And then there is this in class

public void onPageFinished(final WebView webView, final String d) { ... if (!this.c && !TextUtils.isEmpty((CharSequence)d)) { miui.globalbrowser.common_business.g.b.a("page_load_event_finish", "url", this.a(d)); } ... } public void onPageStarted(final WebView webView, final String e, final Bitmap bitmap) { ... if (!this.b && !TextUtils.isEmpty((CharSequence)e)) { miui.globalbrowser.common_business.g.b.a("page_load_event_start", "url", this.a(e)); } ... }
That’s the code sending all visited websites to an analytics server. Once when the page starts loading, and another time when it finishes. And the Xiaomi blog post explains why this code exists: “The URL is collected to identify web pages which load slowly; this gives us insight into how to best improve overall browsing performance.”

Are you convinced by this explanation? Because I’m not. If this is all about slow websites, why not calculate the page load times locally and transmit only the slow ones? This still wouldn’t be great for privacy but an order of magnitude better than what Xiaomi actually implemented. Xiaomi really needs to try harder if we are to assume incompetence rather than malice here. How was it decided that sending all visited addresses is a good compromise? Was privacy even considered in that decision? Would they still make the same decision today? And if not, how did they adapt their processes to reflect this?

But there are far more cases where their analytics code collects too much data. In class we’ll see:

final HashMap<String, String> hashMap = new HashMap<String, String>(); hashMap.put("used_searchengine",; hashMap.put("search_position", miui.globalbrowser.common_business.g.e.c()); hashMap.put("search_method", miui.globalbrowser.common_business.g.e.b()); hashMap.put("search_word", s); miui.globalbrowser.common_business.g.b.a("search", hashMap);
So searching from the navigation bar won’t merely track the search engine used but also what you searched for. In the class we see for example:

final HashMap<String, String> hashMap = new HashMap<String, String>(); hashMap.put("op", s); hashMap.put("suffix", s2); hashMap.put("url", s3); if (d.c(s4)) { s = "privacy"; } else { s = "general"; } hashMap.put("type", s); b.a("download_files", hashMap);
This isn’t merely tracking the fact that files were downloaded but also the URLs downloaded. What kind of legitimate interest could Xiaomi have here?

And then this browser appears to provide some custom user interface for YouTube videos. Almost everything is being tracked there, for example in class

final HashMap<String, String> hashMap = new HashMap<String, String>(); hashMap.put("op", "search"); hashMap.put("search_word", text); hashMap.put("search_type", s); hashMap.put("page", this.w); miui.globalbrowser.common_business.g.b.a("youtube_search_op", hashMap);
Why does Xiaomi need to know what people search on YouTube? And not just that, elsewhere they seem to collect data on what videos people watch and how much time they spend doing that. Xiaomi also seems to know what websites people have configured in their speed dial and when they click those. This doesn’t leave a good impression, could it be surveillance functionality after all?

Conclusions If you use Mint Browser (and presumably Mi Browser Pro similarly), Xiaomi doesn’t merely know which websites you visit but also what you search for, which videos you watch, what you download and what sites you added to the Quick Dial page. Heck, they even track which porn site triggered the reminder to switch to incognito mode! Yes, if Xiaomi wants anybody to believe that this wasn’t malicious they have a lot more explaining to do.

The claim that this data is anonymized cannot be maintained either. Even given the random user ID (which appears to be permanent by mistake) deducing user’s identity should be easy, we’ve seen it before. But they also transmit user’s Xiaomi account ID if they know it, which is directly linked to the user’s identity.

Xiaomi now announced that they will turn off collection of visited websites in incognito mode. That’s a step in the right direction, albeit a tiny one. Will they still collecting all the other data in incognito mode? And even if not, why collect so much data during regular browsing? What reason is there that justifies all these privacy violations?

Update (2020-05-07): I looked into the privacy-related changes implemented in Mint Browser 3.4.3. It’s was a bigger improvement than what it sounded like, the “statistics” collection functionality can be disabled entirely. However, you have to make sure that you have “Incognito Mode” turned on and “Enhanced Incognito Mode” turned off – that’s the only configuration where you can have your privacy.

Share RecommendKeepReplyMark as Last Read

From: FJB3/2/2021 11:07:46 AM
   of 3027

Google Free Android Smartphones are Now Available in the U.S.
Furqan Shahid

3 minutes

Whenever you are in the market looking for a new Android smartphone, it is safe to say that Google services will be the main part of the service. However, what if we tell you that there is one service that actually lets you buy Android devices that are free of Google, and those smartphones are finally making their way into the U.S.

/e/ Foundation is Offering Renowned Smartphones But Without Proper Android and Google Experience On Them According to a report, the /e/ Foundation has been offering refurbished smartphones running "deGoogled" Android since 2019, and the focus back then was just towards the European markets due to the limited supplies of the phones. However, the situation has now changed, and they have enough stock to start offering "deGoogled" smartphones in the U.S. as well. They even come in their own retail box.

You can clearly see that the company has put in some effort in offering these smartphones. At the moment, the /e/ Foundation is offering two phones in the U.S., Starting with a refurbished Galaxy S9 for $380 and a Galaxy S9+ for $430, both of which are fantastic, to say the least. These phones are classed as "premium refurbished," this means that the phones are fully functional, the batteries have been tested, and the camera works fine, too. In addition to that, you are getting a 1-year warranty, carrier unlocked, and they also come with a headset, a quick start guide, and a SIM card tool removal.

So, what exactly are you getting with a Google-free Android phone? Well, Android without Google services is called /e/ OS as the Foundation explains,

We have removed many pieces of code that send your personal data to remote servers without your consent. We don’t scan your data in your phone or in your cloud space, and we don’t track your location hundred times a day or collect what you’re doing with your apps.

Clearly, there are some consequences. You lose access to the Google Play Store, for starters, but your phone does ship with open source apps like browser, email, calendar, maps, and camera. Since you are still getting Android under the hood, the phone can run Android apps, and you can download over 60,000 apps directly from the phone.

While the /e/ Foundation does have an ambitious goal of protecting people's privacy, we live in an age where nothing is really private, so a phone that caters to those concerned about their privacy makes very little sense. If you are still interested in checking it out, you can do so by going here.

Share RecommendKeepReplyMark as Last Read

From: Ken Adams7/15/2021 1:40:12 PM
   of 3027
If I give up my iPhone for a newer Android, do I lose access to Siri information and help?

If so, does Android (or others) have a similar service?

Share RecommendKeepReplyMark as Last ReadRead Replies (1)

To: Ken Adams who wrote (3018)7/15/2021 1:43:46 PM
From: FJB
   of 3027
Android has a similar built in assistant. You can also install Alexa...

Share RecommendKeepReplyMark as Last ReadRead Replies (1)

To: FJB who wrote (3019)7/15/2021 1:47:45 PM
From: Ken Adams
   of 3027
Isn't Alexa only the "in-home" device that turns on lights, etc.? I don't (and won't) have that. I'm only interested in the possibility of replacing "Hey, Siri..." on my iPhone if I don't stay with a newer iPhone.

Share RecommendKeepReplyMark as Last ReadRead Replies (1)

To: Ken Adams who wrote (3020)7/15/2021 2:17:41 PM
From: TimF
   of 3027
Alexa does more than turn on lights. Its Amazon's equivalent of Siri. Google has Google Assistant.

Share RecommendKeepReplyMark as Last ReadRead Replies (1)

To: TimF who wrote (3021)7/15/2021 2:45:59 PM
From: Ken Adams
   of 3027
Thanks. I guess I got the answer I was looking for. I'll probably replace my current iPhone in a few months. My needs are far less than what my current iPhone 7 provides and I'm not willing to spend that kind of money on a replacement with loads of overkill. I want most of the features, just not the speed, storage or initial cost. Looks like there are loads of options open to me for most of that.

As usual, SI provides fast, useful answers. Thanks to both of you guys.

Share RecommendKeepReplyMark as Last Read

From: TimF7/28/2021 1:16:57 PM
   of 3027
old cell phone with optional clip on chatboard for ‘easy’ texting

Share RecommendKeepReplyMark as Last Read

From: Ken Adams8/5/2021 8:15:10 PM
   of 3027
I hope this is the place for my question. I want to replace the QR reader on my iPhone. When I try to use the current one, it interrupts and wants me to sign up for a free trial, them pay a small monthly fee. I've never seen that before and can't see a way around it for this app.

Can someone recommend an app from the App Store that will do what I need, simply, and without a fee?


Share RecommendKeepReplyMark as Last Read
Previous 10 Next 10